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

相关文章

如何自定义Nginx JSON日志格式配置

《如何自定义NginxJSON日志格式配置》Nginx作为最流行的Web服务器之一,其灵活的日志配置能力允许我们根据需求定制日志格式,本文将详细介绍如何配置Nginx以JSON格式记录访问日志,这种... 目录前言为什么选择jsON格式日志?配置步骤详解1. 安装Nginx服务2. 自定义JSON日志格式各

Nginx指令add_header和proxy_set_header的区别及说明

《Nginx指令add_header和proxy_set_header的区别及说明》:本文主要介绍Nginx指令add_header和proxy_set_header的区别及说明,具有很好的参考价... 目录Nginx指令add_header和proxy_set_header区别如何理解反向代理?proxy

Linux修改pip和conda缓存路径的几种方法

《Linux修改pip和conda缓存路径的几种方法》在Python生态中,pip和conda是两种常见的软件包管理工具,它们在安装、更新和卸载软件包时都会使用缓存来提高效率,适当地修改它们的缓存路径... 目录一、pip 和 conda 的缓存机制1. pip 的缓存机制默认缓存路径2. conda 的缓

Redis解决缓存击穿问题的两种方法

《Redis解决缓存击穿问题的两种方法》缓存击穿问题也叫热点Key问题,就是⼀个被高并发访问并且缓存重建业务较复杂的key突然失效了,无数的请求访问会在瞬间给数据库带来巨大的冲击,本文给大家介绍了Re... 目录引言解决办法互斥锁(强一致,性能差)逻辑过期(高可用,性能优)设计逻辑过期时间引言缓存击穿:给

Nginx配置location+rewrite实现隐性域名配置

《Nginx配置location+rewrite实现隐性域名配置》本文主要介绍了Nginx配置location+rewrite实现隐性域名配置,包括基于根目录、条件和反向代理+rewrite配置的隐性... 目录1、配置基于根目录的隐性域名(就是nginx反向代理)2、配置基于条件的隐性域名2.1、基于条件

Ubuntu中Nginx虚拟主机设置的项目实践

《Ubuntu中Nginx虚拟主机设置的项目实践》通过配置虚拟主机,可以在同一台服务器上运行多个独立的网站,本文主要介绍了Ubuntu中Nginx虚拟主机设置的项目实践,具有一定的参考价值,感兴趣的可... 目录简介安装 Nginx创建虚拟主机1. 创建网站目录2. 创建默认索引文件3. 配置 Nginx4

Nginx如何进行流量按比例转发

《Nginx如何进行流量按比例转发》Nginx可以借助split_clients指令或通过weight参数以及Lua脚本实现流量按比例转发,下面小编就为大家介绍一下两种方式具体的操作步骤吧... 目录方式一:借助split_clients指令1. 配置split_clients2. 配置后端服务器组3. 配

Nginx实现前端灰度发布

《Nginx实现前端灰度发布》灰度发布是一种重要的策略,它允许我们在不影响所有用户的情况下,逐步推出新功能或更新,通过灰度发布,我们可以测试新版本的稳定性和性能,下面就来介绍一下前端灰度发布的使用,感... 目录前言一、基于权重的流量分配二、基于 Cookie 的分流三、基于请求头的分流四、基于请求参数的分

如何通过Golang的container/list实现LRU缓存算法

《如何通过Golang的container/list实现LRU缓存算法》文章介绍了Go语言中container/list包实现的双向链表,并探讨了如何使用链表实现LRU缓存,LRU缓存通过维护一个双向... 目录力扣:146. LRU 缓存主要结构 List 和 Element常用方法1. 初始化链表2.

一文详解Nginx的强缓存和协商缓存

《一文详解Nginx的强缓存和协商缓存》这篇文章主要为大家详细介绍了Nginx中强缓存和协商缓存的相关知识,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、强缓存(Strong Cache)1. 定义2. 响应头3. Nginx 配置示例4. 行为5. 适用场景二、协商缓存(协