发现原因:(忽略服务器宽带原因)由于酷易商城首页主要是由多个的商品列表组成,页面读取数据库次数过多,且页面中的图片数量过多,导致页面加载速度过慢,首先想到的就是使用缓存,目前主要是页面缓存和数据缓存。
实践:(asp.net)想到缓存时,对于首页首先想到了页面缓存,这种缓存使用很简单,只需在页头添加以下代码即可:
此项就是asp.net页面缓存的使用方式,下面列出几个常用参数(详细的建议F1下查msdn)
通过上面的方式,把首页的加载速度很快就提了起来,自己也很高兴,但第二天有人反应首页购物车及搜索不好用了,我还纳闷,这些都是之前测试好的啊,中午吃饭时突然才想到,酷易商城首页应用了页面缓存...这下子就找出了原因,页面缓存是针对整个页面进行状态输出的,所以文本框及购物车状态都是不变的,想到后立马就换,接下来该是数据缓存上场了!
数据缓存,即为保存在服务器端内存的数据,客户端加载数据时只要缓存存在,就直接从服务器内存中读取数据,而不用再进行数据库的读取操作(在下也就理解到这里了),所以数据缓存也是广大程序员非常喜欢的利器。接下来就以实例说一下我手下的缓存。
首先说一下系统设计结构,为了快速开发,自己整理了些系统开发中常用的功能模块,当然,缓存操作也包括在内,整个类不大,在此贴出来:
以上就是缓存操作类,需要声明的一点就是,这里把缓存时间默认为了以小时为单位,这是酷易商城系统决定的。
通过以上静态方法就可以非常方便的进行缓存操作,首先看一下首页商品列表的缓存加载,关键代码如下:
调用方法下:
}
通过几行代码就可以实现对首页单个列表数据的缓存,同理可对其他列表数据进行操作。
荐:为了系统中缓存的维护,推荐把系统中用到的缓存单独保存在类中,或是以常量(const)形式来保存,也可以提高一点效率。
以上是首页列表缓存,下面来看一下单个产品的缓存。
提前预想到要处理的问题:酷易商城中的商品是个容易变动的信息,所以要使当前商品显示立即更新,就要做好对单个商品缓存更新的处理操作,可以把此过程封装在业务层(Business)。贴下代码:
为了使缓存统一管理,定义了商品缓存的前缀名称,即上面代码。
具体的操作代码如下:
代码很简单,需要注意的就是,当商品更新时需要将当前修改商品缓存进行更新,简单的方法就是更新完商品后重新调用一下获取商品的方法,更懒的方法就是修改业务层:在修改方法执行完后直接调用获取方法(有的朋友是在修改完后直接删除缓存,让客户浏览时再次加载,不过这样做总感觉不好)。
附:为了使操作人员手工进行缓存清除操作,可调用方法来清除系统中的缓存,代码如下:
while (c.MoveNext())
{
Cache.Remove(c.Key.ToString());
}