锁定老帖子 主题:试用varnish
精华帖 (0) :: 良好帖 (0) :: 新手帖 (0) :: 隐藏帖 (0)
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
作者 | 正文 | ||||||||||||||||||||||||||||||||||||||||||||||||||||||
发表时间:2011-09-15
简介: 反向代理服务器,适用于对静态资源的访问,比如图片,可通过缓存提高访问速度。 官网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%
参考: 声明:ITeye文章版权属于作者,受法律保护。没有作者书面许可不得转载。
推荐链接
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||
返回顶楼 | |||||||||||||||||||||||||||||||||||||||||||||||||||||||
发表时间:2011-09-16
varnish没那么脆,直接并发提高到2万测试吧,跟tomcat之类是数量级的差别,不是百分比。
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||
返回顶楼 | |||||||||||||||||||||||||||||||||||||||||||||||||||||||
发表时间:2011-09-16
myreligion 写道
varnish没那么脆,直接并发提高到2万测试吧,跟tomcat之类是数量级的差别,不是百分比。
并发2w很痛苦,使用root账户才让ab测试通过,不过tomcat没测试成功。 tomcat没有想象的这么弱,还是varnish没这么强悍?还是用同一张图片测试,ab和测试对象在同一台服务器。
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||
返回顶楼 | |||||||||||||||||||||||||||||||||||||||||||||||||||||||
发表时间:2011-09-16
为啥不用apache等http服务器?
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||
返回顶楼 | |||||||||||||||||||||||||||||||||||||||||||||||||||||||
发表时间:2011-09-16
kaneg 写道 为啥不用apache等http服务器?
apache更偏向于传统的负载均衡,如果考虑性能和降低资源损耗,nginx是更好的选择。 静态资源的访问,一般选择varnish或者squid,这是它们的专长。 |
|||||||||||||||||||||||||||||||||||||||||||||||||||||||
返回顶楼 | |||||||||||||||||||||||||||||||||||||||||||||||||||||||
浏览 3759 次