8.1.1 为什么使用缓存
1、NoSQL指的是Not only Sql 而不是 No Sql,作为一种统称,包括了k-v的数据库和内存管理
2、缓存的三个要素:命中率,缓存更新策略、缓存最大数据量
8.1.2 命中率
1、命中率是指请求缓存次数和返回正确次数的比例。(正相关)
2、Query Cache:将SQL语句以及结果做HASH映射后保存在一定的内存区域。
3、只有Select语句会被缓存
4、命中率hit = Qcache_queries_in_cache / Com_select
5、如果数据经常更新,QueryCache就会失效,甚至造成负担
8.1.3 缓存更新策略(以Query Cache为例)
1、FIFO先进先出策略(MySql就是使用这种)
2、LFU策略:最少使用的元素会被清理
3、LRU策略:最近最少使用的元素被清理。
8.1.4 缓存最大数据量
1、缓存最大数据量对于像数据库这种,则是由参数决定;对于基于内存的k-v,则是由OS决定的。
2、超过缓存最大数据量一般会做如下处理:
[if !supportLists]l [endif]停止缓存服务,所有缓存数据被清空
[if !supportLists]l [endif]拒绝写入,不再对缓存进行更新
[if !supportLists]l [endif]根据缓存更新策略清除旧数据
[if !supportLists]l [endif]在上一个方案的基础上,对旧数据进行备份
8.2.1 文件缓存机制
1、模板的作用之一就是把动态PHP代码“编译”成静态的HTML代码,思路:
[if !supportLists]a) [endif]判断是否需要缓存
[if !supportLists]b) [endif]判断是否存在对应的静态文件
[if !supportLists]c) [endif]判断静态文件是否过期
8.2.2 文件缓存开源产品Secache
8.3 Opcode缓存
1、一个PHP运行完,所有的变量都会被回收,这样可以避免内存泄漏,但同样无法复用之前的数据,因此Opcode就产生了。
2、php的语言引擎Zend执行php代码时候,会把代码经过分成Token,词法分析过程转成Opcode的过程。
8.3.1 eAccelerato下载及使用
8.4 客户端缓存
[if !supportLists]1. [endif]客户端缓存规则
[if !supportLists]a) [endif]如果响应头告诉缓存器不要缓存,缓存器就不会缓存
[if !supportLists]b) [endif]如果请求信息带有认证或者安全加密的,相应内容不会缓存
[if !supportLists]c) [endif]如果回应中不存在校验器(ETag或者Last-Modified头信息),缓存服务器会认为缺乏直接更新度信息,内容不缓存
[if !supportLists]2. [endif]HTTP协议中的缓存使用
[if !supportLists]a) [endif]三个标识Last-Modified Expires ETag
[if !supportLists] i. [endif]Expires:过期时间,HTTP的日期时间是格林威治时间GMT,而不是本地时间
[if !supportLists] ii. [endif]Cache-Control:响应头信息,通过这个属性可以让网站owner全面控制内容
[if !supportLists] iii. [endif]ETag:服务器生成的唯一标识符,“被请求变量的实体标志”,给URL的唯一标记。
[if !supportLists]b) [endif]一些小窍门
[if !supportLists] i. [endif]不经常改变图片或者页面 启用缓存,使用Cache-Control:max-age属性设置一个较长的过期时间。
[if !supportLists] ii. [endif]定期更新的内容设置一个缓存服务器可识别的max-age属性或过期时间
[if !supportLists] iii. [endif]尽量不使用POST,因为POST返回的内容大部分缓存服务器不会缓存。
[if !supportLists] iv. [endif]不要在URL中加入对每个用户的识别信息