设为首页 收藏本站
查看: 834|回复: 0

[经验分享] varnish,squid,apache,nginx缓存的侧重点

[复制链接]
发表于 2016-12-27 08:48:03 | 显示全部楼层 |阅读模式
  http://www.cnblogs.com/google4y/archive/2011/09/19/2181251.html 

群里总是有人在问cache用什么,有varnish,squid,apache,nginx这几种,到底是我们用什么架构cache。 

1、从这些功能上。varnish和squid是专业的cache服务,而apache,nginx这些都是第三方模块完成。 

2、要做cache服务的话,我们肯定是要选择专业的cache服务,优先选择squid和varnish。 

varnish本身的技术上优势要高于squid,它采用了“Visual Page Cache”技术,在内存的利用上,Varnish比Squid具有优势,它避免了Squid频繁在内存、磁盘中交换文件,性能要比Squid高。varnish是不能cache到本地硬盘上的。 

还有强大的通过Varnish管理端口,可以使用正则表达式快速、批量地清除部分缓存 

squid的优势在于完整的庞大的cache技术资料,和很多的应用生产环境(这应该与squid早出来有关)。 

3、谈谈nginx,nginx是用第三方模块ncache做的缓冲,其性能基本达到varnish,但在架构中nginx一般作为反向(静态文件现在用nginx的很多,并发能支持到2万+)。在静态架构中,如果前端直接面对的是cdn活着前端了4层负载的话,完全用nginx的cache就够了。 

4、本人觉得如果是在apache服务上提升性能,做一些本地cache是完全可以的,但如果在系统架构中用apache做cache服务,那就有点牛头不对马尾了。 

--------------------------------------- 

以下是转载了一个同学的测试数据 

一,测试环境 

1,硬件是奔腾双核,机子三年前买的。系统是archlinux 

2,测试varnish和squid的时候,web服务用的apache 

3,测试apache的时候,启动了5个进程,不过随着压力的增加,进程会增加的。 

4,测试nginx的时候,启动了十个nginx进程,20个php-cgi进程 

5,varnish,squid,nginx用的是反向代理的形势,也就是说访问图片的时候,要先透过缓存工具 

二,测试 

1,varnish 

[iyunv@BlackGhost bin]# /usr/local/bin/webbench -c 100 -t 20 http://127.0.0.1:8080/00/01/RwGowEtWvcQAAAAAAAAWHH0Rklg81.gif 
Webbench - Simple Web Benchmark 1.5 
Copyright (c) Radim Kolar 1997-2004, GPL Open Source Software. 

Benchmarking: GET http://127.0.0.1:8080/00/01/RwGowEtWvcQAAAAAAAAWHH0Rklg81.gif 
100 clients, running 20 sec. 

Speed=476508 pages/min, 47258114 bytes/sec. 
Requests: 158836 susceed, 0 failed. 

varnish的缓存效率命中率真的好高,看下图: 

varnish 
varnish 

访问了这么次,没有缓存只有一次,效率真的很高。 

2,squid 

[iyunv@BlackGhost bin]# /usr/local/bin/webbench -c 100 -t 20 http://localhost:9000/00/01/RwGowEtWvcQAAAAAAAAWHH0Rklg81.gif 
Webbench - Simple Web Benchmark 1.5 
Copyright (c) Radim Kolar 1997-2004, GPL Open Source Software. 

Benchmarking: GET http://localhost:9000/00/01/RwGowEtWvcQAAAAAAAAWHH0Rklg81.gif 
100 clients, running 20 sec. 

Speed=133794 pages/min, 7475018 bytes/sec. 
Requests: 44598 susceed, 0 failed. 

从测试效果来说,squid挺让我失望的,在测试前,我心里是这样估计的,缓存最好的是varnish,其次是squid,然后nginx,最后是apache,现在呢,squid是最差的。后来我看了一下log文件,发现正常情况下,缓存和没有缓存的比率不是1:2,如果在高压力下,缓存和没有缓存的比率更小。 

3,apache 

[iyunv@BlackGhost conf]# /usr/local/bin/webbench -c 100 -t 20 http://localhost/00/01/RwGowEtWvcQAAAAAAAAWHH0Rklg81.gif 
Webbench - Simple Web Benchmark 1.5 
Copyright (c) Radim Kolar 1997-2004, GPL Open Source Software. 

Benchmarking: GET http://localhost/00/01/RwGowEtWvcQAAAAAAAAWHH0Rklg81.gif 
100 clients, running 20 sec. 

Speed=160890 pages/min, 15856005 bytes/sec. 
Requests: 53630 susceed, 0 failed. 

4,nginx 

[iyunv@BlackGhost conf]# /usr/local/bin/webbench -c 100 -t 20 http://localhost:10000/00/01/RwGowEtWvcQAAAAAAAAWHH0Rklg81.gif 
Webbench - Simple Web Benchmark 1.5 
Copyright (c) Radim Kolar 1997-2004, GPL Open Source Software. 

Benchmarking: GET http://localhost:10000/00/01/RwGowEtWvcQAAAAAAAAWHH0Rklg81.gif 
100 clients, running 20 sec. 

Speed=304053 pages/min, 30121517 bytes/sec. 
Requests: 101351 susceed, 0 failed. 

从上面的测试结果我们可以发现,varnish > nginx > apache > squid,我想这个结果,根大家预期的结果有点出入,因为squid做老牌文件缓存工具怎么会这么差呢,squid的命中率低,我在网上查了一下,很多人都是这样的,这个可能根个人配置有关系,也许真正的高手,才能让squid发挥最大功力。

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.iyunv.com/thread-319947-1-1.html 上篇帖子: nginx+tomcat7+memcached做集群以及session复制 下篇帖子: me_nginx+tomcat+memcached实现session共享配置过程
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表