论坛首页 Java企业应用论坛

试用varnish

浏览 3759 次
锁定老帖子 主题:试用varnish
精华帖 (0) :: 良好帖 (0) :: 新手帖 (0) :: 隐藏帖 (0)
作者 正文
   发表时间:2011-09-15  

简介:

反向代理服务器,适用于对静态资源的访问,比如图片,可通过缓存提高访问速度。

官网https://www.varnish-cache.org/

 

试用心得:

原来项目的图片是通过tomcat来访问的,图片访问量占到所有请求的20%左右。 并且图片不多,决大部分都是重复访问。于是想使用缓存来减少磁盘IO的消耗。很自然就用到了varnish,比较新、性能也很强劲的缓存服务器,squid的替换者。

 

不过在redhat企业版5.2rhel5.2)上安装颇费了周折,原因就是rhel5最高只支持varnish 2.0.6。我之前安装过3.0.12.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%

 

参考:

http://blog.s135.com/post/313/

   发表时间:2011-09-16  
varnish没那么脆,直接并发提高到2万测试吧,跟tomcat之类是数量级的差别,不是百分比。
0 请登录后投票
   发表时间:2011-09-16  
myreligion 写道
varnish没那么脆,直接并发提高到2万测试吧,跟tomcat之类是数量级的差别,不是百分比。

 

并发2w很痛苦,使用root账户才让ab测试通过,不过tomcat没测试成功。

tomcat没有想象的这么弱,还是varnish没这么强悍?还是用同一张图片测试,ab和测试对象在同一台服务器。

 

线程数

10000

循环次数

5

总次数

5w

 

每秒请求数

平均响应时间(毫秒)

tomcat

2068

4834

varnish

4647

2151

提升

124%

55%

 

线程数

20000

循环次数

 

总次数

5w

 

每秒请求数

平均响应时间(毫秒)

tomcat

未通过

未通过

varnish

2604

7680

提升

 

 

 

0 请登录后投票
   发表时间:2011-09-16  
为啥不用apache等http服务器?
0 请登录后投票
   发表时间:2011-09-16  
kaneg 写道
为啥不用apache等http服务器?

apache更偏向于传统的负载均衡,如果考虑性能和降低资源损耗,nginx是更好的选择。

静态资源的访问,一般选择varnish或者squid,这是它们的专长。
0 请登录后投票
论坛首页 Java企业应用版

跳转论坛:
Global site tag (gtag.js) - Google Analytics