建站技術網專注分享網站建設技術,網站建設教程,真正幫你學會做網站技術,輕松解決網站建設過程中遇到的常見問題,為廣大站長服務。 網站地圖 | 收藏本站 | 訂閱
域名投資,就來找米網,認準網址:www.zhaomi.cc 專業仿站,就到仿站網:www.fangzhan.org
  站內公告: ·帝國cms教程內容已更新,歡迎關注     ·建站技術網采用阿里云服務器,備案已通    
您當前的位置:建站技術網 > cms教程 > Wordpress教程

加速WordPress技巧:Redis緩存輸出的HTML頁面

時間:2019-04-26 23:31:15  來源:網絡收集  整理: 建站技術網 www.txwlqq.com     點擊:0次
Redis是一個高級的key-value存儲系統,類似memcached,所有內容都存在內存中,因此每秒鐘可以超過10萬次GET操作。
我下面提出的解決方案是在Redis中緩存所有輸出的HTML 內容而無需再讓WordPress重復執行頁面腳本。這里使用Redis代替Varnish設置簡單,而且可能更快。
安裝 Redis
如果你使用的是 Debian 或者衍生的操作系統可使用如下命令安裝 Redis:
apt-get install redis-server
或者閱讀 安裝指南
使用 Predis 作為 Redis 的 PHP 客戶端
你需要一個客戶端開發包以便 PHP 可以連接到 Redis 服務上。
這里我們推薦 Predis. 上傳 predis.php 到 WordPress 的根目錄。
前端緩存的PHP腳本
步驟1:在WordPress 的根目錄創建新文件 index-with-redis.php ,內容如下:

復制代碼
代碼如下:

<?php
// Change these two variables:
$seconds_of_caching = 60*60*24*7; // 7 days.
$ip_of_this_website = '204.62.14.112';
/*
- This file is written by Jim Westergren, copyright all rights reserved.
- See more here: www.jimwestergren.com/wordpress-with-redis-as-a-frontend-cache/
- The code is free for everyone to use how they want but please mention my name and link to my article when writing about this.
- Change $ip_of_this_website to the IP of your website above.
- Add ?refresh=yes to the end of a URL to refresh it's cache
- You can also enter the redis client via the command prompt with the command "redis-cli" and then remove all cache with the command "flushdb".
*/
// Very necessary if you use Cloudfare:
if (isset($_SERVER['HTTP_CF_CONNECTING_IP'])) {
$_SERVER['REMOTE_ADDR'] = $_SERVER['HTTP_CF_CONNECTING_IP'];
}
// This is from WordPress:
define('WP_USE_THEMES', true);
// Start the timer:
function getmicrotime($t) {
list($usec, $sec) = explode(" ",$t);
return ((float)$usec + (float)$sec);
}
$start = microtime();
// Initiate redis and the PHP client for redis:
include("predis.php");
$redis = new Predis/Client('');
// few variables:
$current_page_url = "http://".$_SERVER['HTTP_HOST'].$_SERVER['REQUEST_URI'];
$current_page_url = str_replace('?refresh=yes', '', $current_page_url);
$redis_key = md5($current_page_url);
// This first case is either manual refresh cache by adding ?refresh=yes after the URL or somebody posting a comment
if (isset($_GET['refresh']) || substr($_SERVER['REQUEST_URI'], -12) == '?refresh=yes' || ($_SERVER['HTTP_REFERER'] == $current_page_url && $_SERVER['REQUEST_URI'] != '/' && $_SERVER['REMOTE_ADDR'] != $ip_of_this_website)) {
require('./wp-blog-header.php');
$redis->del($redis_key);
// Second case: cache exist in redis, let's display it
} else if ($redis->exists($redis_key)) {
$html_of_current_page = $redis->get($redis_key);
echo $html_of_current_page;
echo "<!-- This is cache -->";
// third: a normal visitor without cache. And do not cache a preview page from the wp-admin:
} else if ($_SERVER['REMOTE_ADDR'] != $ip_of_this_website && strstr($current_page_url, 'preview=true') == false) {
require('./wp-blog-header.php');
$html_of_current_page = file_get_contents($current_page_url);
$redis->setex($redis_key, $seconds_of_caching, $html_of_current_page);
echo "<!-- Cache has been set -->";
// last case: the normal WordPress. Should only be called with file_get_contents:
} else {
require('./wp-blog-header.php');
}
// Let's display some page generation time (note: CloudFlare may strip out comments):
$end = microtime();
$t2 = (getmicrotime($end) - getmicrotime($start));
if ($_SERVER['REMOTE_ADDR'] != $ip_of_this_website) {
echo "<!-- Cache system by Jim Westergren. Page generated in ".round($t2,5)." seconds. -->";
}
?>

或者直接下載 index-with-redis.php
步驟2:將上述代碼中的 IP 地址替換成你網站的 IP 地址
步驟3:在.htaccess 中將所有出現 index.php 的地方改為 index-with-redis.php ,如果你使用的是 Nginx 則修改 nginx.conf 中的 index.php 為 index-with-redis.php(并重載 Nginx : killall -s HUP nginx)。
性能測試
1.沒有Redis 的情況下,平均首頁執行1.614 秒,文章頁0.174 秒(無任何緩存插件)
2.使用Redis 的情況下,平均頁面執行時間0.00256秒
我已經在我的博客中使用了如上的方法進行加速很長時間了,一切運行良好。
其他建議
我的環境是Nginx + PHP-FPM + APC + Cloudflare + Redis. 安裝在一個 nano VPS 中,無緩存插件。
請確認使用了gzip壓縮,可加快訪問速度。
訪問 wp-admin
要訪問 wp-admin 必須使用 /wp-admin/index.php 代替原來的 /wp-admin/.
標簽:
文章標題:加速WordPress技巧:Redis緩存輸出的HTML頁面
文章網址:http://www.txwlqq.com/cmsJiaocheng/Wordpress/9145.html
上一篇:Crayon Syntax Highlighter 強大的WP代碼高亮插件安裝方法
下一篇:WordPress 2.8的8個特色的新增功能
來頂一下
返回首頁
返回首頁
相關文章
    無相關信息
推薦資訊
如何通過SEO優化排名賺錢?SEO賺錢方法
如何通過SEO優化排名賺
seo優化教程:網站seo內容優化
seo優化教程:網站seo
SEO細節:企業SEO如何快速為新站做出效果
SEO細節:企業SEO如何
電商技術將如何發展?2018年有這五個大膽預測
電商技術將如何發展?
最新文章
欄目更新
欄目熱門
成人黄色