一、Varnish簡介
Varnish是一款高效能、開源的反向 Proxy伺服器和快取服務器,其開發人員Poul-Henning Kamp是FreeBSD核心的開發人員之一。
Varnish主要運行兩個進程:Management進程和Child進程(也叫Cache進程)。
Management進程主要實現應用新的配置、編譯VCL、監控varnish、初始化varnish以及提供一個命令列介面等。Management進程會每隔幾秒鐘探測一下Child進程以判斷其是否正常運行,如果在指定的時間長度內未得到Child進程的回應,Management將會重啟此Child進程。
二、Varnish工作流程
1)、varnish從用戶端接收請求後,由vcl_recv狀態引擎處理,不能識別的請求將會通過參數pipe交給vcl_pipe狀態引擎,需要尋找緩衝的請求通過lookup參數將會交給vcl_hash狀態引擎,無需緩衝的資料通過參數pass將會交給 vcl_pass狀態引擎;
2)、vcl_hash狀態引擎在接收到請求後會從緩衝中尋找資料,查詢結果有兩種,一種是hit快取命中,另一種是miss緩衝未命中;
3)、vcl_hit狀態引擎將命中的快取資料通過參數deliver交給vcl_deliver狀態引擎,vcl_deliver狀態引擎將資料處理後,最終返回給用戶端;
4)、vcl_miss狀態引擎將未命中的結果參數fetch交給vcl_fetch狀態引擎,vcl_fetch狀態引擎將會從資料庫中尋找資料;
5)、vcl_fetch狀態引擎將從資料庫中查詢到的結果,返回給vcl_deliver狀態引擎;
6)、vcl_deliver狀態引擎將結果返回給master進程,最終返回給用戶端;
三、使用Varnish實現網站動靜分離
實驗環境,三台虛擬機器
Linux:CentOS6.5
Varnish:varnish-3.0.4-1.el6.x86_64
Nginx:nginx-1.4.7
Varnish主機:兩塊網卡,外網IP 172.16.36.10,內網IP 192.168.0.10
Web伺服器1:IP 192.168.0.20,用於作靜態檔案伺服器
Web伺服器2:IP 192.168.0.30,用於作動態程式伺服器
前提說明:
varnish的設定檔為vcl尾碼,位於/etc/varnish/目錄,緩衝通常用於提升響應速度,一般而言,可以緩衝html靜態頁面、圖片、js指令碼、css樣式表,因為動態指令碼語言編寫的頁面需要使用指令碼引擎處理,因此沒有緩衝的必要性;nginx本身就有緩衝及反向 Proxy功能,完全可以實現web服務的動靜分離,不過以緩衝功能作對比,varnish的緩衝顯然比nginx更專業,所以要作快取服務器,可以試試varnish,本次操作將以實驗性的目的,使用varnish實現web服務動靜分離;
1、安裝Varnish
# rpm -ivh varnish-3.0.4-1.el6.x86_64.rpm varnish-docs-3.0.4-1.el6.x86_64.rpm varnish-libs-3.0.4-1.el6.x86_64.rpm
2、配置varnish
1)、編輯varnish指令碼的設定檔/etc/sysconfig/varnish,將varnish監聽的連接埠修改為80;
2)、建立檔案/etc/varnish/web.vcl,編輯varnish緩衝規則;
#定義後端伺服器backend web1 { .host="192.168.0.20"; .port="80";}backend web2 { .host="192.168.0.30"; .port="80";}#只允許本機使用purgers要求方法清除緩衝acl purgers { "127.0.0.1"; "172.16.0.0"/16;}sub vcl_recv { if(req.request=="PURGE"){ if(!client.ip~purgers) { error 405 "Mothod not allow"; } }#靜態資源交給web1伺服器 if(req.url ~ "\.(html|htm|shtml|css|js|jpg|png|gif|jpeg)"){ set req.backend=web1; }#php頁面交給web2伺服器,並跳過緩衝 if(req.url ~ "\.php") { set req.backend=web2; return(pass); } return(lookup);}#將命中的緩衝清除sub vcl_hit { if (req.request == "PURGE") { purge; error 200 "Purged OK"; }}#如果請求清除的資源不在緩衝列表中,返回404狀態sub vcl_miss { if (req.request == "PURGE") { purge; error 404 "Not in cache"; }}#如果請求清除的資源是一個不可快取的資源,返回502狀態sub vcl_pass { if (req.request == "PURGE") { error 502 "Purged on a passed object."; }}#緩衝對象存活時間sub vcl_fetch { if(req.url ~ "\.(html|htm|shtml|css|js|jpg|png|gif|jpeg)"){ set beresp.ttl=7200s; }}#將結果返回給用戶端並在回應標頭部添加兩欄位,顯示命中與否,並顯示後端響應的web伺服器sub vcl_deliver { if(obj.hits > 0) { set resp.http.X-Cache="HIT from" + " " + server.ip; }else{ set resp.http.X-Cache="MISS"; } set resp.http.Backend-IP=req.backend;}
3)、將配置載入至varnish;
3.1)、串連varnish;
3.2)、載入配置;
3.3)、使用配置;
4)、配置兩台web伺服器,分別安裝nginx與php;
192.168.0.20伺服器,建立兩頁面,index.html與index.php,兩頁面請求輸出結果如下:
192.168.0.30伺服器,建立兩頁面,index.html與index.php,兩頁面請求輸出結果如下:
5)、測試結果,開啟地址:172.16.36.10;
當我們請求html頁面時,無論我們怎麼重新整理請求,緩衝總是命中,並顯示HIT,並且後端伺服器一直是,web1(192.168.0.20);
當我們請求php頁面時,我們不讓他緩衝,那麼緩衝也就永遠不會命中,顯示MISS,並且後端伺服器一直是,web2(192.168.0.30);
6)、清除緩衝;
整個配置完成,varnish實現了動靜分離;