我們知道,PHP讀取MYSQL動態顯示,在訪問量大的情況下,會有很多效能問題,如果租用別人的虛擬機器主機,則會因為CPU消耗過多而被限制CPU,導致網頁無法訪問。我這裡給出一個PHP動態產生HTML的方法,可以極大降低伺服器CPU負荷。
首先設定.htaccess檔案,將動態調用的參數轉換為靜態HTML的URL地址,例如將在post目錄下的檔案,轉寄到根目錄的wp-post.php檔案中,加入的語句類似:
RewriteRule ^post/([a-z0-9\-]+\.html)$ wp-post.php?$1$2
然後修改wp-post.php檔案,在檔案的開頭加入以下PHP代碼:
複製代碼 代碼如下:
ob_start();
$qstring = isset($_SERVER[%26quot;QUERY_STRING%26quot;]) ? $_SERVER[%26quot;QUERY_STRING%26quot;] : %26quot;%26quot;;
define(%26quot;HTML_FILE%26quot;, $_SERVER['DOCUMENT_ROOT'].%26quot;/post/%26quot;.$qstring);
if (file_exists(HTML_FILE))
{
$lcft = filemtime(HTML_FILE);
if (($lcft + 3600) %26gt; time()) //判斷上次產生HTML檔案是否超過1小時,若沒有才直接輸出檔案內容
{
echo(file_get_contents(HTML_FILE));
exit(0);
}
}
之後是現有的PHP的代碼,然後在當前代碼的最後面加上如下的PHP代碼:
複製代碼 代碼如下:
define(%26quot;HTMLMETA%26quot;,%26quot;%26lt;!-- this is a real static html file created at %26quot;.date(%26quot;Y-m-d H:i:s%26quot;).%26quot; --%26gt;%26quot;);
$buffer = ob_get_flush();
$fp = fopen(HTML_FILE, %26quot;w%26quot;);
if ($fp)
{
fwrite($fp, $buffer.HTMLMETA);
fclose($fp);
}
好了,然後查看你的靜態HTML頁面,如果頁面尾部出現了注釋行,說明已經成功的建立了靜態HTML檔案。
這個方法的一個應用就是我先前寫的那個%26ldquo;WordPress年度部落格統計外掛程式%26rdquo;,這個統計外掛程式由於查詢十多次資料庫,很多人訪問的時候會有很大效能問題,使用我介紹的這種動態產生HTML技術後,一天就查詢一次,產生一次統計排行,完美解決了查詢資料庫的效能問題。