我是靠谱客的博主 平常奇迹,最近开发中收集的这篇文章主要介绍多缓存并存,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

昨天在听云风讲的《高性能健壮系统中的内存管理》中,对于其中一些观点很有感触,虽然云风是用C来做网络游戏的,C来做游戏在内存管理上跟网站的内存管理是由很大差异的,但是有很多理论也是相通的。

 

缓存是大家都知道的东西,对于网站来说,一个请求过来,有可能返回用户需要的数据过程中,使用了不止一个缓存,是多个缓存。即软件架构中,多缓存并存。这时候要注意什么?


简单来说一句话。

你如果要在A缓存外再起用了一个B缓存,那么B缓存能提高的性能应该比起直接访问A,性能要提升10倍以上。

 

更具体说一个实际的例子,


CSDN某个具体论坛的帖子列表功能,它启用了三个缓存。从用户访问到数据库,依次是:

1、IIS输出缓存

即ASPX页面的如下设置
<%@ OutputCache Duration="30" VaryByParam="*" %>

2、每个请求进程的缓存;

            CommunityUser user = null;
            //检查用户信息是否在HttpContext中存在
            HttpContext context = HttpContext.Current;
            if (context != null)
                user = context.Items[cacheKey] as CommunityUser;


使用这个缓存是因为一个页面,我们有很多ASCX控件,再加上MasterPage页, 而这些页面对应的代码中,都会需要一些当前用户的信息,如果每次都从更底层的缓存取的话,这个消耗其实也不小。

3、进程外服务上的缓存;
为了保证缓存数据的可扩展性,非IIS进程,其他服务器也可以访问,CSDN的最底层的缓存是使用企业服务来实现的。访问这里的缓存会导致跨进程的,甚至跨服务器的访问。

 

上面三个缓存, 每个缓存一但命中,对他的访问,比下一级的缓存都起码有10倍以上的性能提高。就类似.net的垃圾回收中的0级对象区,1级对象区,2级对象区。 级数越低,访问性能越高,但是高级数的却是不可缺少的。

最后

以上就是平常奇迹为你收集整理的多缓存并存的全部内容,希望文章能够帮你解决多缓存并存所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(66)

评论列表共有 0 条评论

立即
投稿
返回
顶部