Nginx 缓存刷新问题

2016-05-10 20:48:57 7919

在使用 Nginx 的过程中,因为 Nginx 本地使用了缓存,然后发布了静态资源后, CDN 回源的时候,发现没有正常回源,经过查询发现,是因为 Nginx 本地有缓存,而有没有对缓存进行刷新的原因,要刷新本地缓存,可以安装 Purge 模块。

Nginx 的缓存设置:

代码如下:


location /
      {
       proxy_cache cache_go;
       proxy_cache_valid 200 304 1d;
       proxy_cache_key $host$uri$is_args$args;
       proxy_set_header Host  $host;
       proxy_set_header X-Forwarded-For  $remote_addr;
       proxy_pass http://www.landui.com:8800;
       expires      3024010s;

 

       }

       location ~ /purge(/.*)
       {
        #设置只允许指定的IP或IP段才可以清除URL缓存。
        allow            127.0.0.1;
        deny             all;
        proxy_cache_purge    cache_go   $host$1$is_args$args;
       }

 

 Purge 模块是用来清除缓存的,首先下载安装 Puerge 模块。

下载 Purge 模块:
wget http://www.landui.com/files/ngx_cache_purge-1.2.tar.gz

 解压:
tar -zxvf ngx_cache_purge-1.2.tar.gz

 再编译前先使用如下命令查看 nginx 的编译选项:

代码如下:


/home/nginx/sbin/nginx -V
nginx version: xxxx
TLS SNI support enabled
configure arguments: --prefix=/home/nginx-1.2.8 --with-pcre=../pcre-8.31 --with-zlib=../zlib-1.2.3 --with-openssl=../openssl-1.0.0d --with-http_ssl_module --with-http_stub_status_module --without-mail_pop3_module --without-mail_imap_module --without-mail_smtp_module --add-module=../ngx_cache_purge-1.5 --add-module=../perusio-nginx-http-concat-321e344 --add-module=../ngx_http_vipshop_hostname_filter --with-ld-opt=-static

 

 上面我的编译显示有 puerge 模块,是因为我已经编译过了,然后在原有的编译参数后面加上:

复制代码 代码如下:


--add-module=/home/ngx_cache_purge-1.5

 

 退出 Nginx ,并重新启动:

复制代码 代码如下:


./nginx -s quit
./nginx

 

 配置 Puerge :

 代码如下:


location ~ /purge(/.*)
       {
        #设置只允许指定的IP或IP段才可以清除URL缓存。
        allow            127.0.0.1;
        deny             all;
        proxy_cache_purge    cache_go   $host$1$is_args$args;
       }

 

 清楚 Nginx 缓存的方式,比如你的 url 是 http://www.landui.com/test/test.js
 那清除该 js 缓存的命令即为:

代码如下:


curl http://www.landui.com/purge/test/test.js

 

 通用的方式就是:

 代码如下:


curl http://www.landui.com/purge/uri

 

 其中 uri 就是你的 URL “http://www.landui.com/test/test.js” 的 “test/test.js” 部分。

提交成功!非常感谢您的反馈,我们会继续努力做到更好!

这条文档是否有帮助解决问题?

非常抱歉未能帮助到您。为了给您提供更好的服务,我们很需要您进一步的反馈信息:

在文档使用中是否遇到以下问题: