php 网站如何应对大流量与高并发呢?
首先,确认服务器硬件是否足够支持当前的流量。
普通的P4服务器一般最多能支持每天10万地理IP,如果访问量比这个还要大,则请配置一台更高性能的专用服务器。
否则怎么优化都不能彻底解决性能问题。
其次,优化数据库访问,
前台最好完全静态化,可以完全不用访问数据库,不过对于频繁更新的网站,静态化往往不能满足某些功能,
缓存技术,将动态数据存储到缓存文件中,动态网页直接调用这些文件,而不必在访问数据库。
WordPress和Z-Blog都大量使用这种缓存技术。
如果确实无法避免对数据库的访问,那么可以尝试优化数据库的查询sql避免使用 select * from 这样的语句,每次查询只返回自己需要的结果,避免短时间内的大量sql查询,。
第三 禁止外部的盗链
外部网站的图片或者文件盗链往往会带来大量的负载压力,因此应该严格限制外部对于自身的图片或者文件盗链,好在目前可以简单的通过refer 来控制盗链,Apache自己可以通过配置来禁止盗链,IIS也有一些第三方的ISAPI可以实现同样的功能。
为防止伪造refe代码方式的盗链,可以在图片上增加水印。
第四 控制大文件的下载
大文件的下载会占用很大的流量,并且对于非SCSI硬盘来说,大量文件下载会消耗CPU,使得网站影响能力下降,因此,尽量不要提供超过2M的大文件下载,如果需要提供建议将大文件放在另外一台服务器上。
第五, 使用不同主机分流主要流量
将文件放在不同的主机上,提供不同的镜像供用户下载,比如如果觉得 RSS文件占用 流量大,那么使用FeedBurner或者FeedSky等服务将RSS输出放在其他主机上,这样别人访问的流量压力就大多集中在 FreedBurner 的主机上,RSS就不占用太多资源了。
第六 使用流量分析统计软件
在网站上安装一个流量分析统计软件,可以即时知道那些地方耗费了大量流量,那些页面需要再进行优化,因此,解决流量问题还需要进行精确的统计分析才可以,我推荐使用的流量分析统计软件是 Google Analytics(Google分析)
优化经验:
首先 学会用explain 语句分析select语句, 优化索引,表结构,其次,合理运动memcache等缓存
降低 mysql 的负载
最后 尽量用 facebook的hiphop-php编译下PHP编译,以提高程序效率。