总结PHP缓存技术的多种方法php
这里所说的数据缓存是指数据库查询PHP缓存机制,每次访问页面的时候,都会先检测相应的缓存数据是否存在,若是不存在,就链接数据库,获得数据,并把查询结果序列化后保存到文件中,之后一样的查询结果就直接从缓存表或文件中得到。数据库
1、广泛缓存技术:apache
数据缓存:这里所说的数据缓存是指数据库查询PHP缓存机制,每次访问页面的时候,都会先检测相应的缓存数据是否存在,若是不存在,就链接数据库,获得数据,并把查询结果序列化后保存到文件中,之后一样的查询结果就直接从缓存表或文件中得到。用的最广的例子看Discuz的搜索功能,把结果ID缓存到一个表中,下次搜索相同关键字时先搜索缓存表。举个经常使用的方法,多表关联的时候,把附表中的内容生成数组保存到主表的一个字段中,兄弟连小编提醒:须要的时候数组分解一下,这样的好处是只读一个表,坏处就是两个数据同步会多很多步骤,数据库永远是瓶颈,用硬盘换速度,是这个的关键点。数组
二、页面缓存:缓存
每次访问页面的时候,都会先检测相应的缓存页面文件是否存在,若是不存在,就链接数据库,获得数据,显示页面并同时生成缓存页面文件,这样下次访问的时候页面文件就发挥做用了。(模板引擎和网上常见的一些PHP缓存机制类一般有此功能)服务器
三、时间触发缓存:分布式
检查文件是否存在而且时间戳小于设置的过时时间,若是文件修改的时间戳比当前时间戳减去过时时间戳大,那么就用缓存,不然更新缓存。性能
四、内容触发缓存:代理
当插入数据或更新数据时,强制更新PHP缓存机制。对象
五、静态缓存:
这里所说的静态缓存是指静态化,直接生成HTML或XML等文本文件,有更新的时候重生成一次,适合于不太变化的页面,这就不说了。
以上内容是代码级的解决方案,下面的内容是服务器端的缓存方案,非代码级的,要有多方的合做才能作到
六、内存缓存:
Memcached是高性能的,分布式的内存对象PHP缓存机制系统,用于在动态应用中减小数据库负载,提高访问速度。
七、php的缓冲器:
有eaccelerator, apc, phpa,xcache,这个这个就不说了吧,搜索一堆一堆的,本身看啦,知道有这玩意就OK
八、MYSQL缓存:
这也算非代码级的,经典的数据库就是用的这种方式,看下面的运行时间,0.09xxx之类的
九、基于反向代理的Web缓存:
如Nginx,SQUID,mod_proxy(apache2以上又分为mod_proxy和mod_cache)
十、DNS轮询:
BIND是一款开放源码的DNS服务器软件,这个要提及来就大了,本身搜索去,你们知道有这个东西就好了。
我知道的有的大站就是这样作的,说简单点就是多服务器啦,把同一个页面或文件缓存到不一样的服务器上,按南北自动解析到相关的服务器中。