PHP通过文件存储来实现缓存
在一些数据库数据记录较大,但是服务器有限的时候,可能一条MySQL查询就会好几百毫秒,一个简单的页面一般也有十几条查询,这个时候也个页面加载下来基本要好几秒了,如果并发量高的话服务器基本就瘫痪了,造成一个页面很久也加载不下来,这个时候我们可以使用文件缓存来缓解下MySQL的压力,下面给个使用例子。
[php] view plain copy
-
-
- //页面业务逻辑处理,获得结果
- $objPage = new Page_IndexModel($arrParams);
-
- //一系列的业务逻辑放在了objPage中,调用process方法获得结果集
- $arrResult = $objPage->process();
-
- //获得结果后smarty赋值
- $smarty->assign($arrResult);
-
- //输出模板
- $smarty->display();
-
- ?>
现在我们用文件缓存来略过Page业务处理这一步
[php] view plain copy
-
-
- $cachFile = './index.php';
- //缓存文件存在且时间不超过一小时,则直接使用缓存的结果集,不在进行任何的MySQL查询了
- if(file_exists($cacheFile) && time()-filemtime($cachFile)
- //使用缓存中的结果
- $arrResult = include($cachFile);
- } else {
- $objPage = new Page_IndexModel($arrParams);
- $arrResult = $objPage->process();
- $strContent = "
-
- //将结果集缓存
- file_put_contents($cachFile, $strContent);
- }
-
- //获得结果后smarty赋值
- $smarty->assign($arrResult);
-
- //输出模板
- $smarty->display();
参考来源:
PHP通过文件存储来实现缓存
http://www.lai18.com/content/407149.html
Déclaration:Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn