`
flysnowxf
  • 浏览: 577775 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

试用varnish

    博客分类:
  • Web
阅读更多

简介:

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

官网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/

分享到:
评论

相关推荐

    Varnish Cache v4.0.0-beta1.zip

    由于这是一个beta版本,意味着它可能包含未经过充分测试的功能,适用于开发者和早期采用者进行试用和反馈,以便在正式版本中进行改进。 在实际部署Varnish时,有几点需要注意。首先,要确保正确配置Varnish与后端...

    2021年软件工程师试用期工作总结1000字试用期.docx

    在团队学习方面,我积极参与部门的小组讨论,如学习Linux系统的各种服务发布,包括Apache、Varnish、Lighttpd等。我创建了内部BBS,使得员工无论在公司还是家中都能进行交流和学习。在公司新版本SNS2.5的上线中,我...

    2021年软件工程师试用期工作总结1500字试用期.docx

    通过学习不同类型的网站发布,如apache、varnish、lighttpd等,为未来可能面临的各种场景做好准备。甚至建立了一个内部bbs论坛,增强了部门间的沟通与协作。 最后,积极参与公司新版本sns2.5的内部测试,发现并报告...

    web前端试用期工作总结.doc

    6. **持续学习和自我提升**:计划学习更多复杂服务如Apache、Varnish、Lighttpd等的发布,提升在Nagios、Cacti监控系统的技能,以及Shell脚本编写,以应对突发事件。还计划学习小型机知识和提升英语水平。 7. **...

    2021年有关试用期工作总结范文汇编五篇.pdf

    这有助于提升团队协作精神,同时也反映出他们对新技术和工具的掌握,如Apache、Varnish、Lighttpd等服务器发布技术。 随着公司的发展,员工不断适应新的挑战,比如参与SNS2.5新版本的内部测试,提供反馈以改进产品...

    java工程师试用期工作总结报告.doc

    九月份,工程师积极参与团队学习,深化对Linux系统的理解,特别是针对不同类型的网站发布技术,如lighttpd、apache和varnish等。他还创建了部门论坛,增强内部沟通和知识共享。在十月份,他参与到公司sns2.5新版本的...

    2021公司新员工试用期个人工作总结.docx

    了Linux系统,特别是对Apache、Varnish、Lighttpd等不同平台的网站服务器发布进行了研究,这使他在监控和故障处理方面有了充分的准备。他还独立搭建了Nagios监控服务器,通过Nagvis实现了对监控设备的3D效果展示,...

    精品专题(2021-2022年收藏)php试用期工作总结.doc

    6. **网站发布与服务器管理**:熟悉各种Web服务器的部署,如Apache、Varnish、Lighttpd等,是PHP程序员的基础技能,这包括网站的发布和服务器配置。 7. **论坛搭建与管理**:创建内部论坛,促进部门间的交流和学习...

    2021网络维修技术师试用期个人工作总结.docx

    在团队学习中,我积极参与部门的小组讨论,对各种网站类型发布有深入研究,如Apache、Varnish、Lighttpd等,这使我具备了在不同平台上的服务器发布技能。同时,我创建并管理了部门内部的BBS论坛,促进员工之间的交流...

    公司新员工试用期工作总结.doc

    作为一名新加入公司的IT员工,试用期是适应和学习的关键阶段。在这两个月的工作总结中,我体验到了公司积极的工作氛围和强大的团队合作精神。这段时间,我主要负责系统管理和监控,不断提升自己的专业技能。 首先,...

    vclfiddle

    VclFiddle是一个在线工具,用于在沙盒环境中试用 HTTP反向代理。 该名称来自Varnish Configuration Language(VCL)和另一个启发了该项目的工具。 VclFiddle旨在提供一种环境,在该环境中可以以最小的摩擦来复制...

    运维工程师转正工作总结.docx

    作为一名运维工程师,试用期是学习和熟悉公司运作、提升个人技能的关键阶段。在过去的几个月中,我主要负责了以下几个方面的任务: 1. **系统服务维护**:我深入理解了公司网络架构,包括前段节点和源站服务的流量...

    ding2:鼎安装配置文件

    如果您想试用Ding2,可以下载。 ding2-7.x-[version].tar.gz文件包含完整的Drupal安装,包括Drupal Core,第三方模块和运行该站点所需的Ding2代码。制作说明本文档的重置说明了如何下载Drupal并修补内核以运行基于...

Global site tag (gtag.js) - Google Analytics