nginx-缓存proxy_ cache和ngx_cache_purge

2023-10-23 07:50
文章标签 nginx 缓存 cache proxy ngx purge

本文主要是介绍nginx-缓存proxy_ cache和ngx_cache_purge,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前言

      关于缓存的定义,可以去看我另一篇文章的介绍:浏览器/web-缓存知识点梳理

1·expires和Cache-Control

1.1·expires

使用本指令可以控制HTTP应答中的“Expires”和“Cache-Control”的头标,(起到控制页面缓存的作用)。

语法: expires [time|epoch|max|off

默认值: expires off
作用域: http, server, location

例如

配置成负数,就会变成”Cache-Control: no-cache“

配置成整数。就会变成“Cache-Control:max-age=#”,# 为指定时间的秒数。

配置成1d的话,浏览器中就可以看到“Cache-Control:max-age=86400”,86400就是1天的秒数

  location /img {

     alias /export/img/;

     expires 1d;

  }

1.2·Cache-Control

nginx也可以通过添加返回头,来修改Cache-Control的值:

cache-control :
       max-age>0时 直接从游览器缓存中提取;
       max-age<=0 时向server发送http请求确认 ,该资源是否有修改, 有的话 返回200 , 无的话 返回304。

Cache-Control更多的参数以及介绍可以看浏览器/web-缓存知识点梳理

if ($request_filename ~ .*\.(htm|html)$)

  {

     add_header Cache-Control no-cache;

  }

http协议的cache-control的常见取值及其组合释义:
no-cache: 数据内容不能被缓存, 每次请求都重新访问服务器, 若有max-age, 则缓存期间不访问服务器.
no-store: 不仅不能缓存, 连暂存也不可以(即: 临时文件夹中不能暂存该资源).
private(默认): 只能在浏览器中缓存, 只有在第一次请求的时候才访问服务器, 若有max-age, 则缓存期间不访问服务器.
public: 可以被任何缓存区缓存, 如: 浏览器、服务器、代理服务器等.
max-age: 相对过期时间, 即以秒为单位的缓存时间.
no-cache, private: 打开新窗口时候重新访问服务器, 若设置max-age, 则缓存期间不访问服务器.
-  private, 正数的max-age: 后退时候不会访问服务器.
-  no-cache, 正数的max-age: 后退时会访问服务器.

2·Last-Modified和ETag

1) Last-Modified属性通常和Expires或Cache-Control属性配合使用, 因为即使浏览器设置缓存, 当用户点击”刷新”按钮时, 浏览器会忽略缓存继续向服务器发送请求,只要资源更新时间不变,服务器就不需要返回真正的资源,只需要返回304让浏览器在本地缓存获取资源, 这时Last-Modified将能够很好的减小回应开销.

2) ETag将返回给浏览器一个资源ID, 资源如果有了新版本则正常发送并附上新的etag, 如果服务器上该资源的id和etag相同。则不返回资源,返回304,浏览器在本地缓存获取资源, 但是在服务器集群情况下, 每个服务器将返回不同的ID, 因此不建议使用ETag,可以用etag:off;来禁止etag的使用

3·proxy_cache

3.1·proxy_temp_path 指令

      为存储承载从代理服务器接收到的数据的临时文件定义目录。指定目录下支持3级子目录结构,proxy_ cache_ path 中use_temp_path为on的时候,会将文件写到该目录下

      语法: proxy_temp_path path [level1 [level2 [level3]]];

      使用 环境: http, server, location

3.2·proxy_cache_path 指令

      该 指令用于设置缓存文件的存放路径

      语法: proxy_cache_path path [levels= number] keys_zone= zone_name: zone_size [inactive= time] [max_size= size];

      使用 环境: http

      参数解释:

path:缓存存放目录

levels:设置缓存文件目录层次;levels=1:2 表示两级目录

keys_zone:设置缓存名字和共享内存大小

inactive:在指定时间内没人访问则被删除

max_size:最大缓存空间,如果缓存空间满,默认覆盖掉缓存时间最长的资源。

use_temp_path:如果为 off,则 nginx 会将缓存文件直接写入指定的 cache 文件中,而不使用 temp_path 指定的临时存储路径

3.3·proxy_cache 指令

      该 指令 用于 设置 哪个 缓存 区 将被 使用, zone_name 的 值 为 proxy_cache_path 指令 创建 的 缓存 区 名称。

      语法: proxy_cache zone_name;

      使用 环境: http, server, location

3.4·proxy_cache_methods 指令

      该 指令 用于 设置 缓存 哪些 HTTP 方法, 默认 缓存 HTTP GET/ HEAD 方法, 不 缓存 HTTP POST 方法。

      语法: proxy_cache_methods [GET HEAD POST];

      默认值: proxy_cache_methods GET HEAD;

      使用 环境: http, server, location


3.5·proxy_cache_min_uses 指令

      该 指令 用于 设置 缓存 的 最小 使用 次数, 默认值 为 1。若我设置为2则表示每个请求最少被请求两次后会加入到缓存

      语法: proxy_cache_min_uses the_ number;

      使用 环境: http, server, location

3.6·proxy_cache_valid 指令

      该 指令 用于 对不 同 返回 状态 码 的 URL 设置 不同 的 缓存 时间,

      语法: proxy_cache_valid reply_code [reply_code...] time;

      使用 环境: http, server, location

      例如:

            设置 200、 302 状态 的 URL 缓存 10 分钟, 404 状态 的 URL 缓存 1 分钟。

proxy_cache_valid 200 302 10m;

proxy_cache_valid 404 1m;

            如果不 指定 状态 码, 直接 指定 缓存 时间, 则 只有 200、 301、 302 状态 的 URL 缓存 5 分钟。

proxy_cache_valid 5m;

            对 没有 单独 设置 的 状态 码, 全部 设置 缓存 时间 为 1 分钟。

proxy_cache_valid 200 302 10m;

proxy_cache_valid 301 1h;

proxy_cache_valid any 1m;

3.7·proxy_cache_key 指令

      该 指令 用来 设置 Web 缓存 的 Key 值, Nginx 根据 Key 值 md5 哈 希 存储 缓存。 一般 根据$ host( 域名)、$ request_uri( 请求 的 路径) 等 变量 组合 成 proxy_ cache_ key。

      语法: proxy_cache_key line;

      使用 环境: http, server, location

3.8·proxy_cache_bypass 

      该参数设定,什么情况下的请求不读取cache而是直接从后端的服务器上获取资源。
这里的string通常为nginx的一些变量。

      语法:proxy_cache_bypass string;

      使用环境:http, server, location

      例:proxy_cahce_bypass $cookie_nocache $arg_nocache$arg_comment;
      意思是,如果$cookie_nocache $arg_nocache$arg_comment这些变量的值只要任何一个不为0或者不为空时,
则响应数据不从cache中获取,而是直接从后端的服务器上获取。

3.9·proxy_no_cache

      该参数和proxy_cache_bypass类似,指定在什么情况下不缓存

      语法:proxy_no_cache string;

      使用环境:http, server, location

      例:proxy_no_cache $cookie_nocache $arg_nocache $arg_comment;
      表示,如果$cookie_nocache $arg_nocache $arg_comment的值只要有一项不为0或者不为空时,不缓存数据。

4·ngx_cache_purge

ngx_cache_purge是第三方模块,需要在安装的时候编译

ngx_cache_purge模块的作用:用于清除指定url的缓存

如下:

proxy_cache_path /cache/cache levels=1:2 keys_zone=cache_one:200minactive=1d max_size=30g;

location ~ /purge(/.*) {  

         #设置只允许指定的IP或IP段才可以清除URL缓存。

         allow       127.0.0.1;  

         allow       192.168.10.0/24;  

         deny    all;  

         proxy_cache_purge    cache_one   $host$1$is_args$args;  

}  

随便访问一个页面http://127.0.0.1/9.jpg,在/data/nginx/cache下面也会生成相应的缓存文件

查看cache.log,可以看到第一次访问为MISS,第二次为HIT

***19/Mar/2014:10:48:16 +0800 ***MISS ***Cache-Control: - ***Expires: - ***"GET /9.jpg HTTP/1.1" (200) ***     #后面浏览器信息就省略了
***19/Mar/2014:10:48:37 +0800 ***HIT ***Cache-Control: - ***Expires: - ***"GET /9.jpg HTTP/1.1" (304) ***

清除缓存:访问 http://127.0.0.1/purge/9.jpg,页面看到如下信息说明缓存已被清除。

Successful purge
Key : 127.0.0.1/9.jpg

Path: /data/nginx/cache/6/c1/368f9db143996c9f865921f8b2c94c16

5·使用案例

http {

log_format cache '***$time_local '  '***$upstream_cache_status '  '***Cache-Control: $upstream_http_cache_control ' '***Expires: $upstream_http_expires ' '***"$request" ($status) ' '***"$http_user_agent" '; #为需要缓存的静态资源设置一个日子格式,可以记录缓存命中记录

    proxy_temp_path    /data/nginx//temp; #定义 proxy_cache 生成临时文件的根路径。此项在 use_temp_path=off 时不需填写
    proxy_cache_path /data/nginx/cache levels=1:2  keys_zone=cache_test:10m inactive=1d  max_size=10g;

    #这里是配置了一个缓存空间.levels 指定 该 缓存 空间 有 两层 hash 目录, 第一 层 目录 为 1 个 字母, 第二层 为 2 个 字母, 保存 的 文件名 会 类似/data/nginx/cache/c/29/b7f54b2df7773722d382f4809d65029c;keys_zone指定该缓存空间名为cache_test,10m 指 内存 缓存 空间 大小 为 10MB;inactive 的 1d 指 如果 缓存 数据 在 1 天 内 没有 被 访问, 将被 删除; max_ size 的 10g 是指 硬盘 缓存 空间 为 10GB。

    proxy_cache_path /data/nginx/cache levels=1:2  keys_zone=cache_test2:10m inactive=1d  max_size=10g;


    upstream test{
        server 192.168.30.133:80 ;
        server 192.168.30.134:80 ;
    }
    server {
        listen       80;
        proxy_cache  cache_test;  #在这里使用了之前配置的缓存空间cache_test
        server_name  aidan.org;

        #简单使用
        location / {
            proxy_pass  http://test;
            proxy_set_header  Host  $host;
            proxy_set_header  X-Real-IP  $remote_addr;

            proxy_cache_valid 200 206 304 180d; # 根据响应码设置缓存时间,超过这个时间即使缓存文件中有缓存数据,nginx也会回源请求新数据。
        }


        #用于清除缓存,假设一个URL为http://192.168.10.3/test.txt,通过访问http://192.168.10.3/purge/test.txt就可以清除该URL的缓存。此功能需要手动编译模块ngx_cache_purge

location ~ /purge(/.*) {  

         #设置只允许指定的IP或IP段才可以清除URL缓存。

         allow       127.0.0.1;  

         allow       192.168.10.0/24;  

         deny    all;  

         proxy_cache_purge    cache_test   $host$1$is_args$args;  

}  

        #对扩展名为 gif, jpg, jpeg, png, bmp, swf, js, css 的图片,Flash, Js, CSS 文件开启 Web 缓存.其它文件不缓存:

        location ~ .*\.(gif|jpg|jpeg|png|bmp|swf|js|css)$ {

            proxy_cache  cache_test2;  #在这里使用了之前配置的缓存空间cache_test2

            proxy_cache_key $host$uri$is_args$args; # 设置 web 缓存的 key 值. Nginx 根据 key 值的 md5 哈希存储缓存.这里根据 域名,URI,参数 组成 Key

            proxy_cache_valie 200 304 12h;

            proxy_cache_valie 301 302 1m;

            proxy_cache_valie any 1m;

            expires 7d; #缓存时间

     access_log /usr/local/nginx/logs/cache.log cache; #日志

        }


       #不缓存

#表明用户访问login和search两个url的时候,变量$nocache 设置为1

if ($request_uri ~ ^/(login|search)){

 set $nocache 1;

}

location / {

 #....

 proxy_pass http://slbserver_cache;

 #当变量$nocache 为1,不缓存。

 proxy_no_cache $nocache $arg_nocache $arg_comment;

 proxy_cache_key $uri$is_args$args;

}


    }
}

推荐公众号,分享运维知识:龙叔18岁

这篇关于nginx-缓存proxy_ cache和ngx_cache_purge的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/266535

相关文章

解决systemctl reload nginx重启Nginx服务报错:Job for nginx.service invalid问题

《解决systemctlreloadnginx重启Nginx服务报错:Jobfornginx.serviceinvalid问题》文章描述了通过`systemctlstatusnginx.se... 目录systemctl reload nginx重启Nginx服务报错:Job for nginx.javas

Redis缓存问题与缓存更新机制详解

《Redis缓存问题与缓存更新机制详解》本文主要介绍了缓存问题及其解决方案,包括缓存穿透、缓存击穿、缓存雪崩等问题的成因以及相应的预防和解决方法,同时,还详细探讨了缓存更新机制,包括不同情况下的缓存更... 目录一、缓存问题1.1 缓存穿透1.1.1 问题来源1.1.2 解决方案1.2 缓存击穿1.2.1

centos7基于keepalived+nginx部署k8s1.26.0高可用集群

《centos7基于keepalived+nginx部署k8s1.26.0高可用集群》Kubernetes是一个开源的容器编排平台,用于自动化地部署、扩展和管理容器化应用程序,在生产环境中,为了确保集... 目录一、初始化(所有节点都执行)二、安装containerd(所有节点都执行)三、安装docker-

Redis与缓存解读

《Redis与缓存解读》文章介绍了Redis作为缓存层的优势和缺点,并分析了六种缓存更新策略,包括超时剔除、先删缓存再更新数据库、旁路缓存、先更新数据库再删缓存、先更新数据库再更新缓存、读写穿透和异步... 目录缓存缓存优缺点缓存更新策略超时剔除先删缓存再更新数据库旁路缓存(先更新数据库,再删缓存)先更新数

el-select下拉选择缓存的实现

《el-select下拉选择缓存的实现》本文主要介绍了在使用el-select实现下拉选择缓存时遇到的问题及解决方案,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的... 目录项目场景:问题描述解决方案:项目场景:从左侧列表中选取字段填入右侧下拉多选框,用户可以对右侧

使用Nginx来共享文件的详细教程

《使用Nginx来共享文件的详细教程》有时我们想共享电脑上的某些文件,一个比较方便的做法是,开一个HTTP服务,指向文件所在的目录,这次我们用nginx来实现这个需求,本文将通过代码示例一步步教你使用... 在本教程中,我们将向您展示如何使用开源 Web 服务器 Nginx 设置文件共享服务器步骤 0 —

SpringBoot使用注解集成Redis缓存的示例代码

《SpringBoot使用注解集成Redis缓存的示例代码》:本文主要介绍在SpringBoot中使用注解集成Redis缓存的步骤,包括添加依赖、创建相关配置类、需要缓存数据的类(Tes... 目录一、创建 Caching 配置类二、创建需要缓存数据的类三、测试方法Spring Boot 熟悉后,集成一个外

使用Spring Cache时设置缓存键的注意事项详解

《使用SpringCache时设置缓存键的注意事项详解》在现代的Web应用中,缓存是提高系统性能和响应速度的重要手段之一,Spring框架提供了强大的缓存支持,通过​​@Cacheable​​、​​... 目录引言1. 缓存键的基本概念2. 默认缓存键生成器3. 自定义缓存键3.1 使用​​@Cacheab

一文带你搞懂Nginx中的配置文件

《一文带你搞懂Nginx中的配置文件》Nginx(发音为“engine-x”)是一款高性能的Web服务器、反向代理服务器和负载均衡器,广泛应用于全球各类网站和应用中,下面就跟随小编一起来了解下如何... 目录摘要一、Nginx 配置文件结构概述二、全局配置(Global Configuration)1. w

若依部署Nginx和Tomcat全过程

《若依部署Nginx和Tomcat全过程》文章总结了两种部署方法:Nginx部署和Tomcat部署,Nginx部署包括打包、将dist文件拉到指定目录、配置nginx.conf等步骤,Tomcat部署... 目录Nginx部署后端部署Tomcat部署出现问题:点击刷新404总结Nginx部署第一步:打包