静态缓存可以大幅提升网站、接口的访问速度,对提升用户体验非常有帮助,刚好项目上也遇到这样的需求,在 ThinkPHP3.2.3
中实现前台页面静态缓存。
原理
静态缓存也就是将动态语言查询数据库然后渲染后的页面直接转换成文件(或者 json
)存储起来,当用户访问的时候,直接呈现给用户即可。
缓存前:
- 根据用户请求页面解析到对应控制器、方法;
- 查询数据库取出数据;
- 数据处理;
- 将数据渲染到模版输出;
缓存后:
- 根据用户请求定位到静态文件;
- 直接输出静态文件;
静态缓存通过简化处理流程(特别是连接数据库读取数据和数据处理),是可以大幅提升访问速度的。
实现步骤
1. 缓存配置:
在需要缓存的模块配置文件(如 \Application\Home\Conf\config.php
)中加入静态缓存配置:
// 静态缓存配置
'HTML_CACHE_ON' => true, // 开启静态缓存
'HTML_CACHE_TIME' => 3600, // 全局静态缓存有效期(秒)
'HTML_FILE_SUFFIX' => '.html', // 设置静态缓存文件后缀
'HTML_CACHE_RULES' => array( // 定义静态缓存规则
// 定义整个文章控制器
// 'Article:' => 'Article/{:action}_{id}',
// 对商品进行缓存
// 'Product:plist' => 'Product/plist_{id}_{pid}',
// 对单个操作进行缓存
// 'Index:index' => 'Index/index',
// 对Index控制器的所有操作缓存
'Index:' => 'Index/{:action}_{id}',
// 对Download控制器的所有操作缓存
'Download:' => 'Download/{:action}_{id}',
// 对Product控制器的所有操作缓存并设置缓存过期时间为7200秒
'Product:' => array('Product/{:action}_{id}', '7200'),
),
还有更多的静态缓存规则设置参考请官方文档。
2. 更新缓存
大部分情况下,我们不需要更新缓存,因为缓存到了缓存有效期就会自动失效,但有时候,修改模版布局,修改栏目或者更新文章后,需要马上更新缓存以便用户看到的是最新的效果,就需要在后台设置一个更新缓存的功能。
更新缓存的操作 update_cache
,当道控制器中供使用,其中 HTML_PATH
为 ThinkPHP3.2.3
定义的静态文件目录,默认是 APP_PATH . 'Html/'
:
public function update_cache(){
// 更新静态缓存文件
if(del_file_under_dir(HTML_PATH)){
response = encode_return_data(0, '更新静态缓存成功');
}else{response = encode_return_data(10006, '更新静态缓存失败');
}
this->ajaxReturn(response);
}
删除文件夹内的文件通用方法 del_file_under_dir()
,这个放到 function.php
中
/**
* 循环删除目录下的所有文件
* @Author hsu1943
* @DateTime 2018-05-04T10:47:33+0800
* @param string dirName 目录
* @return boolean 是否删除成功
*/
function del_file_under_dir(dirName){
if(handle = opendir( "dirName" )) {
while(false !== (item = readdir(handle))){
if(item != "." &&item != ".."){
if(is_dir("dirName/item")){
del_file_under_dir("dirName/item");
}else{
try {
unlink("dirName/item");
} catch (\Exception e) {
echoe->getMessage();
}
}
}
}
closedir($handle);
return true;
}else{
return false;
}
}