首页 > 代码库 > 文件缓存、内存缓存与静态化页面的取舍
文件缓存、内存缓存与静态化页面的取舍
静态和伪静态都是各有优缺点的
静态的好处是你生成了html文件,那么访问量高的时候,服务器的I/O是一个瓶颈。但数据库的压力小了,而且更新的时候,需要重新生成。
而伪静态刚I/O的瓶颈比静态的要小,但是数据库的压力比较大。
如果访问量和并发比较大的话,就使用静态吧。
================
静态文件分发、分布式非常容易,使用CDN很方便,一般不过期,海量流量应付很轻松,只需加CDN带宽即可。
使用memcache这样的内存缓存一般只缓存部分时间不敏感、业务不复杂的数据。以空间换速度。memcache对数据过期时间的控制能力较好。
文件缓存:一般情况下磁盘IO才是主要压力,除非SQL足够复杂,耗费较多CPU。这个时候也可以交给MySQL的查询缓存解决。文件缓存常见于压力不大的站点或者开源程序使用,具有适应性好、对运行环境要求低的特点。
=================
我来说几句废话,楼主先把缓存的概念理解透再谈缓存。
缓存是什么,缓存就是把低速设备上的文件放入高速设备,把从离终端远的位置移到靠近终端的位置。
over,就是这么简单。
理解了概念,你就不会困惑了。不理解请参考3L。3L就是对这个概念的阐述。
有了CDN,静态访问不是问题,再加上本地缓存,效果更好。
一切快慢都只是相对的,如果你认为访问和操作内存就是最快最好的,天下无敌的,那又错了。
一方面,还有比内存更快的。现在基于JAVA的LMAX架构考虑的深度已经到了CPU的高速缓存这一层了,访问和操作内存,慢!得想办法能直接访问高速缓存,并避免并发争夺问题。另一方面,还有某些场合下比内存访问更合适的,如CDN。当然这个例子可能和主题关系不大。只是说明一切都是相对的。
=======================
文件缓存:
还是要请求PHP,由PHP来读取硬盘上缓存的文件。有时候缓存的是整个页面的HTML,有时候只是缓存部分数据或者变量值。
静态化:
不需要PHP来处理,直接由web server读取文件内容并输出。静态化文件的内容只能是HTML代码或者SHTML代码。好处是性能和分布式上的优势,但是没有PHP来处理灵活。
也有杂合的,比如使用伪静态来统一URL,然后以一定策略来决定是访问PHP还是直接HTML。
=======================
如果纠结,推荐一种方案:伪静态和真静态结合。
如果你看过wordpress的.htaccess文件,可以发现这样的伪静态规则
- # BEGIN WordPress
- <IfModule mod_rewrite.c>
- RewriteEngine On
- RewriteBase /
- RewriteRule ^index\.php$ - [L]
- RewriteCond %{REQUEST_FILENAME} !-f
- RewriteCond %{REQUEST_FILENAME} !-d
- RewriteRule . /index.php [L]
- </IfModule>
- # END WordPress
那如何伪静态+真静态呢?
如果访问压力大,则生成HTML到指定位置,在重写规则里!-f条件不成立,这个时候就是真静态;
如果这个页面访问数量少(比如是去年的新闻页),这个时候真静态意义已经不大了,这个时候可以通过管理后台直接删除这个HTML。这个时候重写规则里!-f条件成立,由PHP分析请求的URL,并输出HTML代码。对用户透明,感觉不到区别。
优点:可伸缩性、节省硬盘、性能和灵活性的最大化
缺点:对静态页面要求内容时效不敏感、要求能够启用重写规则