【ACCESS精品源码栏目提醒】:文章导读:在新的一年中,各位网友都进入紧张的学习或是工作阶段。
网学会员整理了ACCESS精品源码-【精品】PHP缓存技术 - 其它资料的相关内容供大家参考,祝大家在新的一年里工作和学习顺利!
普遍缓存技术数据缓存:这里所说的数据缓存是指数据库查询缓存,每次访问页面的时候都会先检测相应的缓存数据是否存在,如果不存在,就连接数据库,得到数据,并把查询结果序列化后保存到文件中,以后同样的查询结果就直接从缓存表或文件中获得。
用的最广的例子看 Discuz 的搜索功能,把结果 ID 缓存到一个表中,下次搜索相同关键字时先搜索缓存表。
举个常用的方法,多表关联的时候,把附表中的内容生成数组保存到主表的一个字段中,需要的时候数组分解一下,这样的好处是只读一个表,坏处就是两个数据同步会多不少步骤,数据库永远是瓶颈,用硬盘换速度,是这个的关键点。
页面缓存:每次访问页面的时候,都会先检测相应的缓存页面文件是否存在,如果不存在,就连接数据库,得到数据,显示页面并同时生成缓存页面文件,这样下次访问的时候页面文件就发挥作用了。
模板引擎和网上常见的一些缓存类通常有此功能时间触发缓存:检查文件是否存在并且时间戳小于设置的过期时间如果文件修改的时间戳比当前时间戳减去过期时间戳大,那么就用缓存,否则更新缓存。
内容触发缓存:当插入数据或更新数据时,强制更新缓存。
静态缓存:这里所说的静态缓存是指静态化,直接生成 HTML 或 XML 等文本文件,有更新的时候重生成一次,适合于不太变化的页面,这就不说了。
以上内容是代码级的解决方案,我直接 CP 别的框架,也懒得改,内容都差不多,很容易就做到,而且会几种方式一起用,但下面的内容是服务器端的缓存方案,非代码级的,要有多方的合作才能做到内存缓存:Memcached 是高性能的,分布式的内存对象缓存系统,用于在动态应用中减少数据库负载,提升访问速度。
这里说下 Memcached 的例子: 代码复制代码读库的例子: 代码复制代码php 的缓冲器:有 eaccelerator, apc, phpa,xcache,这个这个就不说了吧,搜索一堆一堆的,自己看啦,知道有这玩意就 OKMYSQL 缓存:这也算非代码级的,经典的数据库就是用的这种方式,看下面的运行时间,0.09xxx 之类的我贴段根据蓝色那家伙修改后部分 my.ini 吧,2G 的 MYISAM 表可以在 0.05S 左右,据说他前后改了有快一年代码拷贝框 代码client……default-character-setgbkdefault-storage-engineMYISAMmax_connections600max_connect_errors500back_log200interactive_timeout7200query_cache_size64M……table_cache512……myisam_max_sort_file_size100Gmyisam_max_extra_sort_file_size100Gmyisam_sort_buffer_size128Mkey_buffer_size1024Mread_buffer_size512M……thread_concurrency8复制代码基于反向代理的 Web 缓存:如 Nginx,SQUID,mod_proxyapache2 以上又分为 mod_proxy 和 mod_cacheNGINX 的例子 代码user nobodyworker_processes 4error_log logs/error.log critpid logs/nginx.pidworker_rlimit_nofile 10240events use epoll worker_connections 51200http include mime.types default_type application/octet-stream sendfile on keepalive_timeout 65 tcp_nodelay on server pool upstream bspfrontsvr server 10.10.10.224:80 weight1 server 10.10.10.221:80 weight1 upstream bspimgsvr server 10.10.10.201:80 weight1 upstream bspstylesvr server 10.10.10.202:80 weight1 upstream bsphelpsvr server 10.10.10.204:80 weight1 upstream bspwsisvr server 10.10.10.203:80 weight1 upstream bspadminsvr server 10.10.10.222:80 weight1 upstream bspbuyersvr server 10.10.10.223:80 weight1 upstream bspsellersvr server 10.10.10.225:80 weight1 upstream bsploginsvr server 10.10.10.220:443 weight1 upstream bspregistersvr server 10.10.10.220:80 weight1 log_format test_com remote_addr - remote_user time_local