当前位置 主页 > 服务器问题 > Linux/apache问题 >

    在varnish、squid、apache、nginx中选出一个更好的缓存服务器

    栏目:Linux/apache问题 时间:2018-12-12 14:06

    这篇文章主要介绍了在varnish、squid、apache、nginx中选出一个更好的缓存服务器,需要的朋友可以参考下

    一、varnish、squid、apache、nginx的区别

    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服务,那就有点牛头不对马尾了。

    二、测试varnish、squid、apache、nginx

    一,测试环境

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

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

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

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

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

    二,测试

    1,varnish
    复制代码 代码如下:
    [root@BlackGhost bin]# /usr/local/bin/webbench -c 100 -t 20 /2018img/2018/09/20134419.gif
    Webbench - Simple Web Benchmark 1.5
    Copyright (c) Radim Kolar 1997-2004, GPL Open Source Software.

    Benchmarking: GET /2018img/2018/09/20134419.gif
    100 clients, running 20 sec.

    Speed=476508 pages/min, 47258114 bytes/sec.
    Requests: 158836 susceed, 0 failed.
    varnish的缓存效率命中率真的好高

    2,squid
    复制代码 代码如下:
    [root@BlackGhost bin]# /usr/local/bin/webbench -c 100 -t 20 /2018img/2018/09/20134421.gif
    Webbench - Simple Web Benchmark 1.5
    Copyright (c) Radim Kolar 1997-2004, GPL Open Source Software.

    Benchmarking: GET /2018img/2018/09/20134421.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
    复制代码 代码如下:
    [root@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