轉(zhuǎn)載
http://www.s135.com/post/313/
arnish是一款高性能的開源HTTP加速器,挪威最大的在線報(bào)紙 Verdens Gang (http://www.vg.no) 使用3臺(tái)Varnish代替了原來的12臺(tái)squid,
性能居然比以前更好。
Varnish 的作者Poul-Henning Kamp是FreeBSD的內(nèi)核開發(fā)者之一,他認(rèn)為現(xiàn)在的計(jì)算機(jī)比起1975年已經(jīng)復(fù)雜許多。
在1975年時(shí),儲(chǔ)存媒介只有兩種:內(nèi)存與硬盤。但現(xiàn)在計(jì)算 機(jī)系統(tǒng)的內(nèi)存除了主存外,還包括了cpu內(nèi)的L1、L2,甚至有L3快取。
硬盤上也有自己的快取裝置,因此squid cache自行處理物件替換的架構(gòu)不可能得知這些情況而做到最佳化,
但操作系統(tǒng)可以得知這些情況,所以這部份的工作應(yīng)該交給操作系統(tǒng)處理,這就是 Varnish cache設(shè)計(jì)架構(gòu)。
----------------------------------------------------------------------------------------------------------------------------------------------------------------------------
?
今天寫的這篇關(guān)于Varnish的文章,已經(jīng)是一篇可以完全替代Squid做網(wǎng)站緩存加速器的詳細(xì)解決方案了。
網(wǎng)上關(guān)于Varnish的資料很少,中文資料更是微乎其微,希望本文能夠吸引更多的人研究、使用Varnish。
在我看來,使用Varnish代替Squid的理由有三點(diǎn):
1、Varnish采用了“Visual Page Cache”技術(shù),在內(nèi)存的利用上,Varnish比Squid具有優(yōu)勢(shì),
它避免了Squid頻繁在內(nèi)存、磁盤中交換文件,性能要比Squid高。
2、Varnish的穩(wěn)定性還不錯(cuò),我管理的一臺(tái)圖片服務(wù)器運(yùn)行Varnish已經(jīng)有一個(gè)月,沒有發(fā)生過故障,而進(jìn)行相同工作的Squid服務(wù)器就倒過幾次。3、通過Varnish管理端口,可以使用正則表達(dá)式快速、批量地清除部分緩存,這一點(diǎn)是Squid不能具備的。
下面來安裝Varnish網(wǎng)站緩存加速器(Linux系統(tǒng)):
1、創(chuàng)建www用戶和組,以及Varnish緩存文件存放目錄(/var/vcache):
/usr/sbin/groupadd www -g 48
/usr/sbin/useradd -u 48 -g www www
mkdir -p /var/vcache
chmod +w /var/vcache
chown -R www:www /var/vcache
2、創(chuàng)建Varnish日志目錄(/var/logs/):
mkdir -p /var/logs
chmod +w /var/logs
chown -R www:www /var/logs
3、編譯安裝varnish:
wget http://blog.s135.com/soft/linux/varnish/varnish-1.1.2.tar.gz
tar zxvf varnish-1.1.2.tar.gz
cd varnish-1.1.2
./configure --prefix=/usr/local/varnish
make && make install
4、創(chuàng)建Varnish配置文件:
vi /usr/local/varnish/vcl.conf
輸入以下內(nèi)容:
引用
backend myblogserver {?
set backend.host = "192.168.0.5";?
set backend.port = "80";?
}
acl purge {
"localhost";
"127.0.0.1";
"192.168.1.0"/24;
}
sub vcl_recv {
if (req.request == "PURGE") {
if (!client.ip ~ purge) {
error 405 "Not allowed.";
}
lookup;
}
if (req.http.host ~ "^blog.s135.com") {
set req.backend = myblogserver;?
if (req.request != "GET" && req.request != "HEAD") {
pipe;
}
else {
lookup;
}
}
else {
error 404 "Zhang Yan Cache Server";?
lookup;
}
}
sub vcl_hit {
if (req.request == "PURGE") {
set obj.ttl = 0s;
error 200 "Purged.";
}
}
sub vcl_miss {
if (req.request == "PURGE") {
error 404 "Not in cache.";
}
}
sub vcl_fetch {
if (req.request == "GET" && req.url ~ "\.(txt|js)$") {
set obj.ttl = 3600s;
}
else {
set obj.ttl = 30d;
}
}
這里,我對(duì)這段配置文件解釋一下:
(1)、Varnish通過反向代理請(qǐng)求后端IP為192.168.0.5,端口為80的web服務(wù)器;
(2)、Varnish允許localhost、127.0.0.1、192.168.0.***三個(gè)來源IP通過PURGE方法清除緩存;
(3)、Varnish對(duì)域名為blog.s135.com的請(qǐng)求進(jìn)行處理,非blog.s135.com域名的請(qǐng)求則返回“Zhang Yan Cache Server”;
(4)、Varnish對(duì)HTTP協(xié)議中的GET、HEAD請(qǐng)求進(jìn)行緩存,對(duì)POST請(qǐng)求透過,讓其直接訪問后端Web服務(wù)器。之所以這樣配置,是因?yàn)镻OST請(qǐng)求一般是發(fā)送數(shù)據(jù)給服務(wù)器的,需要服務(wù)器接收、處理,所以不緩存;
(5)、Varnish對(duì)以.txt和.js結(jié)尾的URL緩存時(shí)間設(shè)置1小時(shí),對(duì)其他的URL緩存時(shí)間設(shè)置為30天。
5、啟動(dòng)Varnish
ulimit -SHn 51200
/usr/local/varnish/sbin/varnishd -n /var/vcache -f /usr/local/varnish/vcl.conf -a 0.0.0.0:80 -s file,/var/vcache/varnish_cache.data,1G -g www -u www -w 30000,51200,10 -T 127.0.0.1:3500 -p client_http11=on
6、啟動(dòng)varnishncsa用來將Varnish訪問日志寫入日志文件:
/usr/local/varnish/bin/varnishncsa -n /var/vcache -w /var/logs/varnish.log &
7、配置開機(jī)自動(dòng)啟動(dòng)Varnish
vi /etc/rc.local
在末尾增加以下內(nèi)容:
引用
ulimit -SHn 51200
/usr/local/varnish/sbin/varnishd -n /var/vcache -f /usr/local/varnish/vcl.conf -a 0.0.0.0:80 -s file,/var/vcache/varnish_cache.data,1G -g www -u www -w 30000,51200,10 -T 127.0.0.1:3500 -p client_http11=on
/usr/local/varnish/bin/varnishncsa -n /var/vcache -w /var/logs/youvideo.log &
8、優(yōu)化Linux內(nèi)核參數(shù)
vi /etc/sysctl.conf
在末尾增加以下內(nèi)容:
引用
net.ipv4.tcp_fin_timeout = 30
net.ipv4.tcp_keepalive_time = 300
net.ipv4.tcp_syncookies = 1
net.ipv4.tcp_tw_reuse = 1
net.ipv4.tcp_tw_recycle = 1
net.ipv4.ip_local_port_range = 5000 65000
再看看如何管理Varnish:
1、查看Varnish服務(wù)器連接數(shù)與命中率:
/usr/local/varnish/bin/varnishstat
2、通過Varnish管理端口進(jìn)行管理:
用help看看可以使用哪些Varnish命令:
/usr/local/varnish/bin/varnishadm -T 127.0.0.1:3500 help
引用
Available commands:
ping [timestamp]
status
start
stop
stats
vcl.load?
vcl.inline?
vcl.use?
vcl.discard?
vcl.list
vcl.show?
param.show [-l] []
param.set?
help [command]
url.purge?
dump.pool
3、通過Varnish管理端口,使用正則表達(dá)式批量清除緩存:
(1)、例:清除類似http://blog.s135.com/a/zhangyan.html的URL地址):
/usr/local/varnish/bin/varnishadm -T 127.0.0.1:3500 url.purge /a/
(2)、例:清除類似http://blog.s135.com/tech的URL地址:
/usr/local/varnish/bin/varnishadm -T 127.0.0.1:3500 url.purge w*$
(3)、例:清除所有緩存:
/usr/local/varnish/bin/varnishadm -T 127.0.0.1:3500 url.purge *$
4、一個(gè)清除Squid緩存的PHP函數(shù)(清除Varnish緩存同樣可以使用該函數(shù),無需作任何修改,十分方便):
view plainprint?
<?php?
function purge($ip, $url)?
{?
$errstr = '';?
$errno = '';?
$fp = fsockopen ($ip, 80, $errno, $errstr, 2);?
if (!$fp)?
{?
return false;?
}?
else?
{?
$out = "PURGE $url HTTP/1.1\r\n";?
$out .= "Host:blog.s135.com\r\n";?
$out .= "Connection: close\r\n\r\n";?
fputs ($fp, $out);?
$out = fgets($fp , 4096);?
fclose ($fp);?
return true;?
}?
}?
purge("192.168.0.4", "/index.php");?
?>?
附1:Varnish官方網(wǎng)站:http://www.varnish-cache.org/
附2:2007年12月10日,我寫了一個(gè)每天0點(diǎn)運(yùn)行,按天切割Varnish日志,生成一個(gè)壓縮文件,同時(shí)刪除上個(gè)月舊日志的腳本(/var/logs/cutlog.sh):
/var/logs/cutlog.sh文件內(nèi)容如下:
引用
#!/bin/sh
# This file run at 00:00
date=$(date -d "yesterday" +"%Y-%m-%d")
pkill -9 varnishncsa
mv /var/logs/youvideo.log /var/logs/${date}.log
/usr/local/varnish/bin/varnishncsa -n /var/vcache -w /var/logs/youvideo.log &
mkdir -p /var/logs/youvideo/
gzip -c /var/logs/${date}.log > /var/logs/youvideo/${date}.log.gz
rm -f /var/logs/${date}.log
rm -f /var/logs/youvideo/$(date -d "-1 month" +"%Y-%m*").log.gz
設(shè)置在每天00:00定時(shí)執(zhí)行:
/usr/bin/crontab -e
或者
vi /var/spool/cron/root
輸入以下內(nèi)容:
引用
0 0 * * * /bin/sh /var/logs/cutlog.sh
- 上一篇: Web緩存(配置squid)
- 下一篇: 負(fù)載均衡+Web緩存(Nginx)
更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號(hào)聯(lián)系: 360901061
您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺我的文章對(duì)您有幫助,請(qǐng)用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長(zhǎng)非常感激您!手機(jī)微信長(zhǎng)按不能支付解決辦法:請(qǐng)將微信支付二維碼保存到相冊(cè),切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對(duì)您有幫助就好】元
