静态和伪静态都是各有优缺点的
静态的好处是你生成了html文件,那么访问量高的时候,服务器的I/O是一个瓶颈。但数据库的压力小了,并且更新的时候,须要从新生成。
而伪静态刚I/O的瓶颈比静态的要小,可是数据库的压力比较大。
php
若是访问量和并发比较大的话,就使用静态吧。html
================web
静态文件分发、分布式很是容易,使用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
=======================
若是纠结,推荐一种方案:伪静态和真静态结合。
若是你看过wordpress的.htaccess文件,能够发现这样的伪静态规则
那如何伪静态+真静态呢?
若是访问压力大,则生成HTML到指定位置,在重写规则里!-f条件不成立,这个时候就是真静态;
若是这个页面访问数量少(好比是去年的新闻页),这个时候真静态意义已经不大了,这个时候能够经过管理后台直接删除这个HTML。这个时候重写规则里!-f条件成立,由PHP分析请求的URL,并输出HTML代码。对用户透明,感受不到区别。
优势:可伸缩性、节省硬盘、性能和灵活性的最大化
缺点:对静态页面要求内容时效不敏感、要求可以启用重写规则