本篇文章主要介紹php透過檔案儲存來實現快取的技巧,有興趣的朋友參考下,希望對大家有幫助。
本文實例講述了PHP基於檔案儲存實作快取的方法,具體如下:
在某些資料庫資料記錄較大,但是伺服器有限的時候,可能一則MySQL查詢就會好幾百毫秒,一個簡單的頁面一般也有十幾條查詢,這個時候也個頁面加載下來基本要好幾秒了,如果並發量高的話伺服器基本上就癱瘓了,造成一個頁面很久也加載不下來,這個時候我們可以使用檔案快取來緩解下MySQL的壓力,下面給個使用範例。
<?php //页面业务逻辑处理,获得结果 $objPage = new Page_IndexModel($arrParams); //一系列的业务逻辑放在了objPage中,调用process方法获得结果集 $arrResult = $objPage->process(); //获得结果后smarty赋值 $smarty->assign($arrResult); //输出模板 $smarty->display(); ?>
現在我們用檔案快取來略過Page業務處理這一步驟
<?php $cachFile = './index.php'; //缓存文件存在且时间不超过一小时,则直接使用缓存的结果集,不在进行任何的MySQL查询了 if(file_exists($cacheFile) && time()-filemtime($cachFile) < 3600) { //使用缓存中的结果 $arrResult = include($cachFile); } else { $objPage = new Page_IndexModel($arrParams); $arrResult = $objPage->process(); $strContent = "<?php \n return ".var_export($arrResult, true)."\n;"; //将结果集缓存 file_put_contents($cachFile, $strContent); } //获得结果后smarty赋值 $smarty->assign($arrResult); //输出模板 $smarty->display();
總結:以上就是這篇文章的全部內容,希望能對大家的學習有所幫助。
相關推薦:
以上是php透過檔案儲存來實現快取的技巧的詳細內容。更多資訊請關注PHP中文網其他相關文章!