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

使用Nginx的proxy_cache缓存功能取代Squid

阅读更多

  [文章作者:张宴 本文版本:v1.2 最后修改:2009.01.12 转载请注明原文链接:http://blog.s135.com/nginx_cache/ ]

   Nginx从0.7.48版本开始,支持了类似Squid的缓存功能。这个缓存是把URL及相关组合当作Key,用md5编码哈希后保存在硬盘上,所以 它可以支持任意URL链接,同时也支持404/301/302这样的非200状态码。虽然目前官方的Nginx Web缓存服务只能为指定URL或状态码设置过期时间,不支持类似Squid的PURGE指令,手动清除指定缓存页面,但是,通过一个第三方的Nginx 模块,可以清除指定URL的缓存。

  Nginx的Web缓存服务主要由proxy_cache相关指令集和fastcgi_cache相关指令集构成,前者用于反向代理时,对后端内容源服务器进行缓存,后者主要用于对FastCGI的动态程序进行缓存。两者的功能基本上一样。

   最新的Nginx 0.8.32版本,proxy_cache和fastcgi_cache已经比较完善,加上第三方的ngx_cache_purge模块(用于清除指定 URL的缓存),已经可以完全取代Squid。我们已经在生产环境使用了 Nginx 的 proxy_cache 缓存功能超过两个月,十分稳定,速度不逊于 Squid。

  在功能上,Nginx已经具备Squid所拥有的Web缓存加速功能、清除 指定URL缓存的功能。而在性能上,Nginx对多核CPU的利用,胜过Squid不少。另外,在反向代理、负载均衡、健康检查、后端服务器故障转移、 Rewrite重写、易用性上,Nginx也比Squid强大得多。这使得一台Nginx可以同时作为“负载均衡服务器”与“Web缓存服务器”来使用。



  1、Nginx 负载均衡与缓存服务器在 Linux 下的编译安装:

ulimit -SHn 65535
wget ftp://ftp.csx.cam.ac.uk/pub/software/programming/pcre/pcre-8.00.tar.gz
tar zxvf pcre-8.00.tar.gz
cd pcre-8.00/
./configure
make && make install
cd ../

wget http://labs.frickle.com/files/ngx_cache_purge-1.0.tar.gz
tar zxvf ngx_cache_purge-1.0.tar.gz

wget http://nginx.org/download/nginx-0.8.32.tar.gz
tar zxvf nginx-0.8.32.tar.gz
cd nginx-0.8.32/
./configure --user=www --group=www --add-module=../ngx_cache_purge-1.0 --prefix=/usr/local/webserver/nginx --with-http_stub_status_module --with-http_ssl_module
make && make install
cd ../

 



  2、/usr/local/webserver/nginx/conf/nginx.conf 配置文件内容如下:

user  www www;

worker_processes 8;

error_log  /usr/local/webserver/nginx/logs/nginx_error.log  crit;

pid        /usr/local/webserver/nginx/nginx.pid;

#Specifies the value for maximum file descriptors that can be opened by this process.
worker_rlimit_nofile 65535;

events
{
  use epoll;
  worker_connections 65535;
}

http
{
  include       mime.types;
  default_type  application/octet-stream;

  charset  utf-8;
      
  server_names_hash_bucket_size 128;
  client_header_buffer_size 32k;
  large_client_header_buffers 4 32k;
  client_max_body_size 300m;
      
  sendfile on;
  tcp_nopush     on;

  keepalive_timeout 60;

  tcp_nodelay on;

  client_body_buffer_size  512k;
  proxy_connect_timeout    5;
  proxy_read_timeout       60;
  proxy_send_timeout       5;
  proxy_buffer_size        16k;
  proxy_buffers            4 64k;
  proxy_busy_buffers_size 128k;
  proxy_temp_file_write_size 128k;

  gzip on;
  gzip_min_length  1k;
  gzip_buffers     4 16k;
  gzip_http_version 1.1;
  gzip_comp_level 2;
  gzip_types       text/plain application/x-javascript text/css application/xml;
  gzip_vary on;

  #注:proxy_temp_path和proxy_cache_path指定的路径必须在同一分区
  proxy_temp_path   /data0/proxy_temp_dir;
  #设置Web缓存区名称为cache_one,内存缓存空间大小为200MB,1天没有被访问的内容自动清除,硬盘缓存空间大小为30GB。
  proxy_cache_path  /data0/proxy_cache_dir  levels=1:2   keys_zone=cache_one:200m inactive=1d max_size=30g;
  
  upstream backend_server {
    server   192.168.8.43:80 weight=1 max_fails=2 fail_timeout=30s;
    server   192.168.8.44:80 weight=1 max_fails=2 fail_timeout=30s;
    server   192.168.8.45:80 weight=1 max_fails=2 fail_timeout=30s;
  }

  server
  {
    listen       80;
    server_name  www.yourdomain.com 192.168.8.42;
    index index.html index.htm;
    root  /data0/htdocs/www;  

    location /
    {
         #如果后端的服务器返回502、504、执行超时等错误,自动将请求转发到upstream负载均衡池中的另一台服务器,实现故障转移。
         proxy_next_upstream http_502 http_504 error timeout invalid_header;
         proxy_cache cache_one;
         #对不同的HTTP状态码设置不同的缓存时间
         proxy_cache_valid  200 304 12h;
         #以域名、URI、参数组合成Web缓存的Key值,Nginx根据Key值哈希,存储缓存内容到二级缓存目录内
         proxy_cache_key $host$uri$is_args$args;
         proxy_set_header Host  $host;
         proxy_set_header X-Forwarded-For  $remote_addr;
         proxy_pass http://backend_server;
         expires      1d;
    }
    
    #用于清除缓存,假设一个URL为http://192.168.8.42/test.txt,通过访问http://192.168.8.42/purge/test.txt就可以清除该URL的缓存。
    location ~ /purge(/.*)
    {
     #设置只允许指定的IP或IP段才可以清除URL缓存。
     allow            127.0.0.1;
     allow            192.168.0.0/16;
     deny            all;
     proxy_cache_purge    cache_one   $host$1$is_args$args;
    }    

    #扩展名以.php、.jsp、.cgi结尾的动态应用程序不缓存。
    location ~ .*\.(php|jsp|cgi)?$
    {
         proxy_set_header Host  $host;
         proxy_set_header X-Forwarded-For  $remote_addr;
         proxy_pass http://backend_server;
    }

    access_log  off;
  }
}

 



  3、启动 Nginx:

/usr/local/webserver/nginx/sbin/nginx

 



  4、清除指定的URL缓存示例:

  点击在新窗口中浏览此图片

分享到:
评论

相关推荐

    squid、varnish、ngx_cache的性能测试对比报告

    首先,从测试环境来看,本次测试所使用的Squid、Ngx_cache(也就是Varnish)、Nginx_cache均运行在具有单硬盘资源的服务器上,并为缓存分配了180G的存储空间。这意味着测试结果更侧重于考察三者在单盘存储条件下的...

    NGINX 缓存使用指南1

    启用Nginx的缓存功能,需要配置 `proxy_cache_path` 和 `proxy_cache`。以下是一个简单的配置示例: ```nginx proxy_cache_path /path/to/cache levels=1:2 keys_zone=my_cache:10m max_size=10g inactive=60m; ...

    nginx tomcat负载均衡缓存服务器集群.docx

    Nginx 自 0.7.48 版本起开始支持类似 Squid 的缓存功能,能对任意 URL 链接进行缓存,包括非 200 状态码。缓存机制由 `proxy_cache` 和 `fastcgi_cache` 指令集实现,分别对应反向代理和FastCGI动态程序。通过第三方...

    Nginx缓存Cache的配置方案以及相关内存占用问题解决

    - 使用内存缓存:通过`proxy_cache_use_stale`和`proxy_cache_lock`等指令,让Nginx优先使用内存中的缓存,减少磁盘IO操作。 - 监控和清理:定期检查并清理无用的缓存文件,可以编写脚本或利用Nginx的`proxy_cache_...

    nginx学习总结五(nginx反向代理)

    Nginx 0.8.32版本,proxy_cache和fastcgi_cache已经比较完善,加上第三方的ngx_cache_purge模块(用于清除指定URL的缓存),已经可以完全取代Squid。 在功能上,Nginx已经具备Squid所拥有的Web缓

    使用Xcache缓存器加速PHP网站的配置方法

     由于国内网站备案比较麻烦,所以笔者便把网站放到... 目前用于Web的缓存系统很多,包括squid、varnish、Nginx自带的proxy_cache、FastCGI中的fastcgi_cache、APC、Xcache等。  像squid、varnish、Nginx自带的proxy

    apache集群范例

    6. **缓存技术**:例如使用mod_cache和mod_disk_cache模块来缓存静态内容,减少服务器负载。更高级的解决方案如Varnish或 Squid可以作为反向代理,进一步提高缓存效率。 7. **日志管理和分析**:使用logrotate管理...

    开源基础架构和集群最佳实践

    ### 开源基础架构和集群最佳实践 ...cache_dir ufs /var/spool/squid 10000 16 256 ``` ##### 2、Varnish - **安装**: 使用包管理器安装Varnish。 - **配置**: 编辑配置文件`/etc/varnish/default.vcl`。 ...

    php缓存技术介绍

    9. 基于反向代理的Web缓存:Nginx、SQUID和Apache的mod_proxy及mod_cache等代理服务器可以缓存HTTP响应,减轻后端服务器的压力。 10. DNS轮询:DNS服务器如BIND可以实现负载均衡,通过DNS解析将用户请求分散到多个...

    PHP网页缓存技术优点及代码实例

    10. **基于反向代理的Web缓存**:如Nginx、Squid和Apache的mod_proxy及mod_cache,它们在服务器端缓存HTTP响应,减少服务器直接处理请求的压力。 11. **DNS轮询**:通过BIND等DNS服务器软件实现,将同一内容分发到...

    PHP缓存技术的多种方法小结

    9. 基于反向代理的Web缓存:如Nginx、SQUID和Apache的mod_proxy及mod_cache模块,它们作为服务器之间的中间层,负责缓存和分发请求,减轻服务器压力。 10. DNS轮询:DNS轮询是一种负载均衡策略,通过配置DNS服务器...

    linux服务器配置重点实例的源文件收集.pdf

    Proxy服务器用于代理网络访问,通常使用 Squid。配置包括定义缓存策略、访问控制列表、代理端口等。在`squid.conf`中,可以通过`http_access`规则控制访问权限,`cache_dir`定义缓存位置,`visible_hostname`设置...

Global site tag (gtag.js) - Google Analytics