简介:
反向代理服务器,适用于对静态资源的访问,比如图片,可通过缓存提高访问速度。
官网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%
|
参考:
http://blog.s135.com/post/313/
分享到:
相关推荐
由于这是一个beta版本,意味着它可能包含未经过充分测试的功能,适用于开发者和早期采用者进行试用和反馈,以便在正式版本中进行改进。 在实际部署Varnish时,有几点需要注意。首先,要确保正确配置Varnish与后端...
在团队学习方面,我积极参与部门的小组讨论,如学习Linux系统的各种服务发布,包括Apache、Varnish、Lighttpd等。我创建了内部BBS,使得员工无论在公司还是家中都能进行交流和学习。在公司新版本SNS2.5的上线中,我...
通过学习不同类型的网站发布,如apache、varnish、lighttpd等,为未来可能面临的各种场景做好准备。甚至建立了一个内部bbs论坛,增强了部门间的沟通与协作。 最后,积极参与公司新版本sns2.5的内部测试,发现并报告...
6. **持续学习和自我提升**:计划学习更多复杂服务如Apache、Varnish、Lighttpd等的发布,提升在Nagios、Cacti监控系统的技能,以及Shell脚本编写,以应对突发事件。还计划学习小型机知识和提升英语水平。 7. **...
这有助于提升团队协作精神,同时也反映出他们对新技术和工具的掌握,如Apache、Varnish、Lighttpd等服务器发布技术。 随着公司的发展,员工不断适应新的挑战,比如参与SNS2.5新版本的内部测试,提供反馈以改进产品...
九月份,工程师积极参与团队学习,深化对Linux系统的理解,特别是针对不同类型的网站发布技术,如lighttpd、apache和varnish等。他还创建了部门论坛,增强内部沟通和知识共享。在十月份,他参与到公司sns2.5新版本的...
了Linux系统,特别是对Apache、Varnish、Lighttpd等不同平台的网站服务器发布进行了研究,这使他在监控和故障处理方面有了充分的准备。他还独立搭建了Nagios监控服务器,通过Nagvis实现了对监控设备的3D效果展示,...
6. **网站发布与服务器管理**:熟悉各种Web服务器的部署,如Apache、Varnish、Lighttpd等,是PHP程序员的基础技能,这包括网站的发布和服务器配置。 7. **论坛搭建与管理**:创建内部论坛,促进部门间的交流和学习...
在团队学习中,我积极参与部门的小组讨论,对各种网站类型发布有深入研究,如Apache、Varnish、Lighttpd等,这使我具备了在不同平台上的服务器发布技能。同时,我创建并管理了部门内部的BBS论坛,促进员工之间的交流...
作为一名新加入公司的IT员工,试用期是适应和学习的关键阶段。在这两个月的工作总结中,我体验到了公司积极的工作氛围和强大的团队合作精神。这段时间,我主要负责系统管理和监控,不断提升自己的专业技能。 首先,...
VclFiddle是一个在线工具,用于在沙盒环境中试用 HTTP反向代理。 该名称来自Varnish Configuration Language(VCL)和另一个启发了该项目的工具。 VclFiddle旨在提供一种环境,在该环境中可以以最小的摩擦来复制...
作为一名运维工程师,试用期是学习和熟悉公司运作、提升个人技能的关键阶段。在过去的几个月中,我主要负责了以下几个方面的任务: 1. **系统服务维护**:我深入理解了公司网络架构,包括前段节点和源站服务的流量...
如果您想试用Ding2,可以下载。 ding2-7.x-[version].tar.gz文件包含完整的Drupal安装,包括Drupal Core,第三方模块和运行该站点所需的Ding2代码。制作说明本文档的重置说明了如何下载Drupal并修补内核以运行基于...