https://pan.baidu.com/s/1qAfkG1o051ZRUddA66dtww //軟件連接百度雲
首先準備環境關閉防火牆:
上傳軟解包和依賴包:
systemctl stop firewalld //關閉防火牆
setenforce 0 //關閉監控
yum install lrz* -y //可以直接把軟件包拖到xshell當前目錄裏面的命令
libedit-devel-3.0-12.20121213cvs.el7.x86_64.rpm
python-docutils-0.11-0.2.20130715svn7687.el7.noarch.rpm
varnish-5.2.1.tgz
yum install -y gcc gcc-c++ make //安裝編譯器和環境
安裝依賴關係包和所需要的插件:
yum install -y \
libtool \
ncourses-devel \
pcre-devel \
libedit-devel \
libxslt \
groff \
pkgconfig \
ncurses-devel \
python-*
rpm -ivh libedit-devel-3.0-12.20121213cvs.el7.x86_64.rpm
rpm -ivh python-docutils-0.11-0.2.20130715svn7687.el7.noarch.rpm
tar xf varnish-5.2.1.tgz -C /opt
cd /opt/varnish-5.2.1/ //進入解壓後的文件夾中定義需要的模塊
sh autogen.sh //檢查系統環境
./configure \
--prefix=/usr/local/varnish \
--enable-debugging-symbols \
--enable-developer-warnings
make && make install
cd /usr/local/varnish/
ln -s /usr/local/varnish/sbin/varnishd /usr/sbin/
ln -s /usr/local/varnish/bin/* /usr/local/bin/
cp /usr/local/varnish/share/doc/varnish/example.vcl /usr/local/varnish/default.vcl
//配置文件模板拷貝出來用
grep -v "#" default.vcl | grep -v "^$"
vi /usr/local/varnish/default.vclg
修改以下內容:
backend default {
.host = "192.168.80.101"
.port = "80"
}
varnishd -f /usr/local/varnish/default.vcl -a 0.0.0.0:80
//#指定監聽的ip和端口啓動varnish
netstat -anpt | grep varnishd
在另一臺linux虛擬機上搭建一個web服務器(80.101):
systemctl stop firewalld //關閉防火牆
setenforce 0 //關閉監控
yum install -y httpd
vi /etc/httpd/conf/httpd.conf
找到ServerName www.example.com:80吧#去掉
vi /var/www/html/index.html
<h1>server 1</h1>
systemctl start httpd
測試,在windows瀏覽器中輸入http://192.168.80.100(varnish服務器的ip地址)
Varnishlog #查看日誌,實時滾動方式
以上單臺web後端服務器
多臺web後端服務器:
vi /usr/local/varnish/default.vcl
找到以下內容並修改:
vcl 4.0;
import directors; //新增一行,導入一個directors
-----以下增加業務服務器節點-----
backend web1 { #把default修改爲web1,就是後面的web服務器,有幾個web節點就複製幾個backend域
.host = "192.168.80.101"; #後端web服務器的地址
.port = "80"; #web服務器端口
}
backend web2 {
.host = "192.168.80.102";
.port = "80";
}
-----接着以上代碼接着定義調度算法及指定流量轉發----
sub vcl_init { #在init子函數中定義
new bar = directors.round_robin(); //random(隨機) round_robin dns
#定義服務器組,讓新的 bar 等於之前定義的變量directors,後面接輪詢(rr)算法
bar.add_backend(web1); #注意這裏有幾個backend就添加幾個
bar.add_backend(web2);
}
sub vcl_recv {
set req.backend_hint = bar.backend(); //流量轉發給所有結點 注意括號
}
varnishd -C -f /usr/local/varnish/default.vcl > /dev/null
//檢查配置文件是否有錯誤
pkill -9 varnish
varnishd -f /usr/local/varnish/default.vcl
netstat -anpt | grep varnishd
在另一臺linux虛擬機上搭建一個web服務器(80.102):
systemctl stop firewalld //關閉防火牆
setenforce 0 //關閉監控
yum install -y httpd
vi /etc/httpd/conf/httpd.conf
找到ServerName www.example.com:80吧#去掉
vi /var/www/html/index.html
<h1>server 2</h1>
systemctl start httpd
在瀏覽器中輸入192.168.80.100
由於varnish緩存的原因,當我們訪問varnish的時候,並沒有像我們預期的那樣根據rr算法各自訪問後面兩臺web服務器的不同頁面,這時我們讓一臺web服務器網絡中斷,這時varnish就會訪問到另一臺了。
後端主機健康檢測機制:
varnish可以對後端主機進行健康檢測,動態進行移除或恢復後端主機調度列表
probe healthche { 定義健康檢測方法,自定義名稱
.url="/index.html"; #檢測時請求的URL,默認爲"/"
.timeout = 2s; #超時時間
.window = 6 ; #基於最近的多少次檢測來判斷其健康狀態
.threshold = 5; #最近.window中定義的這麼次檢查中至有.threshhold定義的次數是成功的;
.interval = 2s; #檢測頻度;
}
在定義後端服務器時引用檢測方法
backend web1 {
.host = "1921.68.80.100";
.port = "80";
.probe = healthche; #引用檢測方式
}
在varniadm 命令接口中查看檢測狀況,健康狀態檢測backend.list