開啟三臺虛擬機 實戰:使用varnish加速多個不同域名站點的web服務器 varnish:192.168.80.100 //需要聯網 web1:192.168.80.101——www.aa.com web2:192.168.80.102——www.bb.com
三臺服務器全都要操作 systemctl stop firewalld //關閉防火墻 setenforce 0 //關閉監控
yum安裝varnish cd /etc/yum.repos.d/ mv back/* ./
1.安裝varnish(從Centos7開始,varnish已被收入到epel倉庫) yum install epel-release -y //需要聯網 yum -y install varnish
2.新建varnish用戶 useradd -M -s /sbin/nologin varnish
3.varnish配置文件 vi /etc/varnish/varnish.params //主配置文件
vi /etc/varnish/default.vcl //VCL配置文件 sub vcl_recv{ if (req.http.host ~ "(i)^(www.)aa.com$") { set req.http.host = "www.aa.com"; set req.backend_hint = web1; } elsif (req.http.host ~ "(i)^www.bb.com$") { set req.backend_hint = web2; return(hash); } } 判斷當訪問www.aa.com域名時從web1上取數據,訪問www.bb.com域名是到web2取數據。
#添加一個Header標識,以判斷緩存是否命中 sub vcl_deliver { if (obj.hits > 0) { set resp.http.X-Cache = "HIT FROM" + req.http.host; set resp.http.X-Cache-Hits = obj.hits; } else { set resp.http.X-Cache = "MISS FROM" + req.http.host; } return (deliver); }
重啟varnish systemctl restart varnish
vi /etc/hosts 192.168.80.100 www.aa.com 192.168.80.100 www.bb.com
yum install -y elinks //安裝elinks elinks www.aa.com --dump #elinks文本界面瀏覽器
或者:在windows中查找
在另一臺虛擬機搭建一個web服務器:web1(80.101)
yum install httpd -y //安裝http
vi /etc/httpd/conf/httpd.conf 把 ServerName www.example.com:80 前面的#刪除
vi /var/www/html/index.html
在另一臺虛擬機搭建一個web服務器:web2(80.102)
yum install httpd -y //安裝http
vi /etc/httpd/conf/httpd.conf 把 ServerName www.example.com:80 前面的#刪除
vi /var/www/html/index.html
最后在瀏覽器上輸入www.bb.com
————————————————————————————————————————
VCL Varnish Configuration Language (VCL) 是一種動態語言,是varnish配置語言,用來描述請求處理和制定緩存策略。vcl配置內容由manager process 創建的VCC子進程轉換成C語言代碼,再經由gcc編譯成共享對象,最后裝載到cacher process中生效。 VCL文件被分為多個子程序,不同的子程序在不同的時間里執行,比如一個子程序在接到請求時執行,另一個子程序在接受到后端服務器傳送的文件時執行。
VCL處理流程圖
處理過程大致分為如下幾個步驟
1、Receive狀態:請求處理的入口狀態,根據VCL規則判斷該請求應該是Pass或Pipe或者進入Lookup(本地查詢)
2、Lookup狀態,在緩存中查找用戶請求的對象,如果緩存中沒有其請求的對象,后續操作很可能會將其請求的對象進行緩存;進入此狀態后,會在hash表中查找數據,若找到,則進入Hit(命中)狀態,否則進入miss狀態
3、Pass狀態,在此狀態下,會進入后端(源服務器)請求,即進入fetch狀態,不走緩存
4、Fetch狀態,在Fetch狀態下,對請求,進行后端的獲取,發送請求,獲得源服務器的數據,并進行本地的存儲
5、Deliver提供狀態,將獲取到的數據發送給客戶端,然后完成本次請求。
注:
Pass:繞過緩存,既不從緩存中查詢內容或不將內容存儲至緩存中;
Pipe:不對客戶端進行檢測或作出任何操作,而是在客戶端與后端服務器之間建立專用“管道”,并直接將數據在二者之間進行傳送;此時,keep-alive連接中后續傳送的數據都將通過此管道進行直接傳送,并不會出現在任何日志中。
語法 (1)支持注釋 // # /* */ (2)不支持循環 (3)sub $name:用于定義子例程 sub vcl_recv { } (4)有眾多內置的變量,變量的可調用位置與state engine有密切相關性 (5)支持終止語句,return(action),沒有返回值 (6)"域"專用 (7)操作符 =,==,!,&&,||
常用語句 if else set name=value unset name req.http.HEADER:調用請求報文中http協議的指定的變量 req.request:請求方法
varnish變量種類
req——請求
resp——響應
client——客戶端
server——服務端
bereq——向后端請求時產生的req
beresp——后端響應時產生的resp
obj——項目對象
storage——大小
常用變量:
bereq和req:
bereq(req).http.HEADERS: 由varnish發往backend server的請求報文的指定首部;
bereq(req).request:請求方法;
bereq(req).url: 請求路徑
bereq(req).proto: 請求協議
bereq(req).backend:指明要調用的后端主機;
beresp和resp
beresp.proto:響應使用的協議
beresp.status:響應的狀態碼
beresp.reason:原因短語;
beresp.backend.ip:響應的后端ip地址
beresp.backend.name:響應的后端域名
beresp.http.HEADER: 從backend server響應的報文的首部;
beresp.ttl:后端服務器響應的內容的余下的生存時
obj
obj.ttl: 對象的ttl值;
obj.hits:此對象從緩存中命中的次數;
server
server.ip
server.hostname
CDN