项目结构是这样的:
用户 ---------- 代理(.net代码) --------- 项目代码(php)
由于该项目本来是放在.net代码里的,但是现在要迁移到php这边来,可是为了保证原有链接(考虑到用户的体验、seo等),所以在.net代码做了一层代理。即,.net根据 用户请求从php处读取到全部页面内容,然后展现给用户看。
而由于该项目的特殊性,我们需要较高的Qps。使用http_load做压力测试的结果是:
1、使用代理的情况下,75/s
2、不适用代理的情况下,120/s
3、对页面部分内容作了memcache缓存,180/s
4、对页面整个内容作文件缓存,450/s
另外,由于.net那边也对页面整个内容作了全页面缓存,所以方案4并不会正式使用。但是记录下来,在以后没有代理的时候,可以这样用。
详细描述一下方案3和方案4。
方案3:
首先分析页面内容,变动较大的是跟用户小字报(mini博客)相关的,以及页面所有人的详细信息;而变动没那么大的是,照片、视频、个人资料、论坛帖子、好友关系等。而论坛帖子、好友关系的变动频率又可能会大于照片、视频等。
不过考虑到我们暂定的缓存时间为10s,所以,暂时将以上变动不太大的部分都放在一个缓存中,这样页面只需要同memcached交互一次就可以拿到所有缓存内的信息。以后如果发现它们变动的频率特别不一样,再考虑拆分他们。
由于我们不想在写数据时变动缓存中的数据,所以承受了10s内即时数据变化了,也不会反映在页面上的风险。
方案4:
使用php提供的函数,ob_start, ob_get_contents, ob_end_flush来获取页面内容,并写入到文件中,做静态化。具体如下:
-根据登录者与被访问页面的关系,区分缓存文件的名称,比如为cache/c_1.html。
-判断文件修改时间与当前时间的间隔,如果小于设定值,则使用缓存文件
if (time() - filemtime($cache_file) <= PAGE_CACHE_TIME){include($cache_file); exit;}
-否则更新缓存:
ob_start();
// 页面主题
$cache = ob_get_contents();
ob_end_flush();
file_put_contents($cache_file, $cache);