缓存

缓存可以根据存放的地点的不同,分为客户端缓存和服务器端缓存

 

客户端缓存,又可以分为浏览器缓存,网关或代理服务器缓存

网关或代理服务器缓存是将网页缓存到网关服务器中,多用户访问同一个页面的时候,将直接从网关服务器把页面传送给页面。

浏览器缓存,是最靠近用户的缓存,如果启用缓存,用户在访问同一个页面的时候,将不再从服务器下载页面,而是从本机的缓存目录中读取页面,然后在浏览器中展现这个页面。

 

浏览器缓存的控制,可以设置meta标签,可以设置数字,也可以设置时间,如下:

 <meta http-equiv=”expires” content=”3600”>

 <meta http-equiv=”expires” content=”wed,26Feb 1997 08:21:57 GMT”>

 

http头信息如下:

http/1.1 200 OK

Date: Fri,30 Oct 1998 13:19:41 GMT

Server: Apache/1.3.3(Unix)

Cache-Control: max-age=3600,must-revalidate

Expires: Fri,30 Oct 1998 14:19:41 GMT

Last-Modified: Mon,29 Jun 1998 02:28:12 GMT

 

不过现在的网站为了保证用户访问到最新内容,一般很少采用浏览器缓存,取而代之的是更加灵活的服务器缓存。

 

服务端缓存分为:页面缓存,数据缓存,数据库缓存

1.页面缓存

         页面缓存是将动态页面直接生成静态的页面放在服务器端,用户调取相同页面时,静态页面将直接下载到客户端,不再需要通过程序的运行和数据库的访问,大大节约了服务器的负载。

2.数据缓存

         数据缓存框架有 ehcache 和 memcache

         ehcache 有很多缓存的分支(包括页面缓存的模块),但是最为核心的模块还是数据缓存部分。比如:当ehcache和hibernate 进行整合时,能将查出的对象集合放入内存中,下次如果再次查询时,将直接从内存中返回这个数据集合,不再进行数据库的查询。同时你可以配置缓存的刷新模式,有read-only,nonstrict-read-write,read-write几种模式,其中read-only表示缓存是不刷新的(要刷新就需要重启),nonstrict-read-only表示刷新是不及时的,你可以设置超时的时间去刷新,read-write表示在数据发生变化时缓存都会发生刷新,具体怎么配置看具体业务。

         Memcache大致的原理和ehcache相同,将数据采用键值的形式存放在内存中,使用时可以将查询的md5 作为键,查询的结果作为值。相对ehcache而言,memcache是一个工具,ehcache是一个框架,memcache更加底层更加灵活。

 

3.数据库缓存:

         数据库的缓存一般由数据库提供,比如oracle,可以对表建立告诉高速缓存,提高对经常访问数据的访问速度。

近几年的nosql技术,虽然现在归于数据库的一种,但其本质也是缓存技术和数据库技术的一种融合产物。

 

目前缓存的做法分为两种模式:

内存模式:缓存数据存放在服务器的内存空间中。

         优点是:速度快。缺点是:资源有限

文件缓存:缓存数据存放在服务器的硬盘空间中

         优点是:容量大。缺点是:速度偏慢,尤其是在缓存数量巨大时。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值