[nginx]proxy_cache缓存系统

简介: [nginx]proxy_cache缓存系统

前言

proxy_cache是nginx内置的一个缓存系统,可实现减小后端负载的作用。

常用参数说明

参数 说明
proxy_cache_path 缓存文件路径。level表示目录层级,1:2表示两个子目录。keys_zone指定缓存区名称和大小。inactive表示缓存有效期。max_size表示硬盘中缓存的大小。use_temp_path为off时表示缓存文件直接写到cache中而不使用temp_path,避免文件拷贝导致影响性能。
proxy_cache 启用缓存并指定缓存区域
proxy_cache_valid 根据状态码来定义缓存的有效期
proxy_cache_min_uses 被访问多少次后才缓存,默认为1
proxy_cache_methods 指定可以被缓存的请求方法,默认值为 GET HEAD
proxy_cache_convert_head 如果设置为 on 表示允许将请求的 HEAD 方法改成 GET 方法进行缓存;如果设置为 off,则缓存的 key 需要加上$request_method,即$host$request_uri$request_method
proxy_cache_key 设置缓存的 key,默认 key 是完整的 URL
proxy_cache_background_update 允许后台启动一个子请求去更新过期的缓存数据,并提供一个过期的缓存数据响应给客户端,前提是 proxy_cache_use_stale 的配置中包含 updating
proxy_cache_use_stale 允许在某种条件下返回请求时使用过期的缓存数据
proxy_cache_lock 多条相同url请求未命中缓存时,nginx只发送一条请求到后端
proxy_cache_lock_timeout 缓存未命中等待超时后,所有未命中的url请求都会转到后端
proxy_ignore_headers 即便有指定的响应头操作,依然使用缓存

配置示例

http {
  # 设置缓存路径、目录层级(1:2 表示两个子目录)、内存zone的名字和内存大小
  # 缓存有效时间、硬盘最大存储大小、缓存文件直接写到cache文件中而不使用temp_path
  proxy_cache_path /home/apps/nginx/cache levels=1:2 keys_zone=ngxcache:100m inactive=7d max_size=1g use_temp_path=off;
  
  server {
    ...
    
    proxy_cache ngxcache;
    proxy_cache_valid 200 304 5m;
    proxy_cache_valid 301 302 2m;
    proxy_cache_min_uses 1;
    # 添加一个响应头,用来标识请求是否命中缓存
    add_header N-Cache-Status $upstream_cache_status;
    proxy_cache_methods GET HEAD;
    proxy_cache_convert_head on;
    proxy_cache_key $scheme$host$uri$is_args$args;
    proxy_cache_background_update on;
    # 允许在某种条件下返回请求时使用过期的缓存数据
    proxy_cache_use_stale error timeout invalid_header updating http_502 http_503 http_504;
    proxy_cache_lock on;
    proxy_cache_lock_timeout 10;
    # 即便有Vary、Set-Cookie的响应头操作,依然使用缓存
    proxy_ignore_headers Vary Set-Cookie;
    
    proxy_pass http://backend;
  }
}
相关文章
|
2月前
|
消息中间件 缓存 NoSQL
Redis 是一个高性能的键值对存储系统,常用于缓存、消息队列和会话管理等场景。
【10月更文挑战第4天】Redis 是一个高性能的键值对存储系统,常用于缓存、消息队列和会话管理等场景。随着数据增长,有时需要将 Redis 数据导出以进行分析、备份或迁移。本文详细介绍几种导出方法:1)使用 Redis 命令与重定向;2)利用 Redis 的 RDB 和 AOF 持久化功能;3)借助第三方工具如 `redis-dump`。每种方法均附有示例代码,帮助你轻松完成数据导出任务。无论数据量大小,总有一款适合你。
78 6
|
4月前
|
缓存 应用服务中间件 nginx
成功解决 Nginx更新静态资源无效 ,Nginx静态资源更新不及时,Nginx清除缓存
这篇文章讨论了在使用Nginx进行动静分离时遇到的静态资源更新不及时的问题。问题描述了在服务器上更新静态资源后,访问页面时页面没有显示更新的情况。文章提供了解决这个问题的方法,即清除浏览器缓存,并提供了相关参考文章链接。此外,还展示了问题复现的步骤和正常情况的预期结果。
成功解决 Nginx更新静态资源无效 ,Nginx静态资源更新不及时,Nginx清除缓存
|
2月前
|
缓存 Java Shell
Android 系统缓存扫描与清理方法分析
Android 系统缓存从原理探索到实现。
74 15
Android 系统缓存扫描与清理方法分析
|
2月前
|
Kubernetes 监控 测试技术
k8s学习--基于Ingress-nginx实现灰度发布系统
k8s学习--基于Ingress-nginx实现灰度发布系统
124 2
k8s学习--基于Ingress-nginx实现灰度发布系统
|
2月前
|
存储 缓存 监控
|
2月前
|
存储 缓存 负载均衡
Nginx代理缓存机制
【10月更文挑战第2天】
96 4
|
2月前
|
存储 缓存 NoSQL
Nginx缓存
Nginx缓存
30 2
|
3月前
|
缓存 运维 NoSQL
二级缓存架构极致提升系统性能
本文详细阐述了如何通过二级缓存架构设计提升高并发下的系统性能。
131 12
|
4月前
|
缓存 NoSQL Linux
【Azure Redis 缓存】Windows和Linux系统本地安装Redis, 加载dump.rdb中数据以及通过AOF日志文件追加数据
【Azure Redis 缓存】Windows和Linux系统本地安装Redis, 加载dump.rdb中数据以及通过AOF日志文件追加数据
141 1
【Azure Redis 缓存】Windows和Linux系统本地安装Redis, 加载dump.rdb中数据以及通过AOF日志文件追加数据
|
4月前
|
缓存 架构师 数据库
缓存系统稳定性 - 架构师峰会演讲实录
缓存系统稳定性 - 架构师峰会演讲实录