亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

Web緩存(Varnish方案)

系統(tǒng) 1982 0

Web緩存(Varnish方案)

轉(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
更多 0

Web緩存(Varnish方案)


更多文章、技術(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ì)您有幫助就好】

您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺我的文章對(duì)您有幫助,請(qǐng)用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長(zhǎng)會(huì)非常 感謝您的哦!!!

發(fā)表我的評(píng)論
最新評(píng)論 總共0條評(píng)論
主站蜘蛛池模板: 夜夜躁日日躁狠狠久久 | a中文字幕1区 | 阳光灿烂的日子在线观看 | 天天天天色 | 草久在线视频 | 日本欧美三级 | 国产精品久久久久久久久久妇女 | 四虎影院免费在线播放 | 国产69精品久久久久999小说 | 玖玖精品视频在线 | 日本一区二区三区高清福利视频 | 国产精品亚洲综合第一区 | 欧美一级特黄一片免费 | 中文字幕久久久久久精 | 永久黄网站色视频免费观看99 | 精品久久久久久久一区二区手机版 | 精品一成人岛国片在线观看 | 色五婷婷 | 在线观看国产欧美 | 4虎在线观看| 九色 91 | 国产在线一区二区三区 | 日韩高清在线日韩大片观看网址 | 国产成人精品曰本亚洲77美色 | 亚洲性在线 | 青草青青在线视频观看 | 香蕉蕉亚亚洲aav综合 | 91手机在线观看 | 国产精品久久久久久久 | 久久久久久国产精品免费免 | 91视频免费观看网站 | 四虎国产成人免费观看 | 精品精品国产理论在线观看 | 香蕉依人 | 久草免费精品视频 | 中文字幕专区高清在线观看 | 亚洲精品一区二区在线观看 | 欧美影院久久 | 成人午夜在线观看国产 | 日本不卡视频在线观看 | 日韩综合图区 |