简介:
反向代理服务器,适用于对静态资源的访问,比如图片,可通过缓存提高访问速度。
官网https://www.varnish-cache.org/
试用心得:
原来项目的图片是通过tomcat来访问的,图片访问量占到所有请求的20%左右。并且图片不多,决大部分都是重复访问。于是想使用缓存来减少磁盘IO的消耗。很自然就用到了varnish,比较新、性能也很强劲的缓存服务器,squid的替换者。
不过在redhat企业版5.2(rhel5.2)上安装颇费了周折,原因就是rhel5最高只支持varnish 2.0.6。我之前安装过3.0.1和2.1.6,各种编译报错,解决不了。忽然看到官网的这么一句话:
This means that we can not update Varnish in EPEL so the latest version there is Varnish 2.0.6.
安装成功后做了一个和tomcat对比的压力测试,固定访问一张图片的性能提升60%左右。
安装:
tar xf varnish-2.0.6.tar.gz
cd varnish-2.0.6
./autogen.sh
./configure --prefix=~/varnish
make && make install
使用的是普通账号安装,安装在家目录的varnish下
配置:
vi ~/varnish/etc/varnish/default.vcl
backend default {
.host = "127.0.0.1";
.port = "28080";
}
sub vcl_recv {
if(req.url ~ "\.(png|gif|jpg)$") {
return (lookup);
}
return (pass);
}
如果是图片,先查询缓存,其他直接转发到后端服务器。
启动:
varnishd -f ~/varnish/etc/varnish/default.vcl -s malloc,128M -a 0.0.0.0:8000 -T 192.168.102.62:8001
监听端口8000,分配128m的内存
输出日志:
varnishncsa -w ~/logs/varnish/varnish.log &
访问日志输出在~/logs/varnish/varnish.log
优化Linux内核参数(使用root账号):
vi /etc/sysctl.conf
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
生效:
sysctl -p
优化参数:
参考https://www.varnish-cache.org/trac/wiki/Performance
thread_pool_add_delay=2
thread_pools=<Number of cpu cores>
thread_pool_min=<800/number of cpu cores>
thread_pool_max=4000
session_linger=100
4cpu的命令:
varnishd -f ~/varnish/etc/varnish/default.vcl -s malloc,128M -a 0.0.0.0:8000 -T 192.168.102.62:8001 -p thread_pool_add_delay=2 -p thread_pools=4 -p thread_pool_min=200 -p thread_pool_max=4000 -p session_linger=100
在我的测试中,比默认参数性能提高10%左右。
压力测试:
提升60%
线程数 | 200 | 循环次数 | 500 | 总次数 | 10w |
| 每秒请求数 | 平均响应时间(毫秒) | |||
tomcat | 4109 | 48 | |||
varnish | 6864 | 29 | |||
提升 | 67% | 47% |
线程数 | 500 | 循环次数 | 200 | 总次数 | 10w |
| 每秒请求数 | 平均响应时间(毫秒) | |||
tomcat | 4109 | 121 | |||
varnish | 6505 | 76 | |||
提升 | 58% | 37% |
线程数 | 800 | 循环次数 | 125 | 总次数 | 10w |
| 每秒请求数 | 平均响应时间(毫秒) | |||
tomcat | 3904 | 204 | |||
varnish | 6098 | 131 | |||
提升 | 56% | 35% |
参考: