[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;
  }
}
相关文章
|
29天前
|
应用服务中间件 Linux 网络安全
技术指南:如何把docsify项目部署到基于CentOS系统的Nginx中。
总结 与其他部署方法相比,将docsify项目部署到基于CentOS系统的Nginx中比较简单。以上步骤应当帮助你在不花费太多时间的情况下,将你的项目顺利部署到Nginx中。迈出第一步,开始部署你的docsify项目吧!
84 14
|
2月前
|
缓存 负载均衡 应用服务中间件
Nginx缓存的相关知识
总的来说,Nginx的缓存机制是其高性能的重要保证之一,通过合理的配置和管理,可以使网站的访问速度得到大幅提升。
109 28
|
8月前
|
消息中间件 缓存 NoSQL
Redis 是一个高性能的键值对存储系统,常用于缓存、消息队列和会话管理等场景。
【10月更文挑战第4天】Redis 是一个高性能的键值对存储系统,常用于缓存、消息队列和会话管理等场景。随着数据增长,有时需要将 Redis 数据导出以进行分析、备份或迁移。本文详细介绍几种导出方法:1)使用 Redis 命令与重定向;2)利用 Redis 的 RDB 和 AOF 持久化功能;3)借助第三方工具如 `redis-dump`。每种方法均附有示例代码,帮助你轻松完成数据导出任务。无论数据量大小,总有一款适合你。
143 6
|
6月前
|
存储 缓存 监控
Linux缓存管理:如何安全地清理系统缓存
在Linux系统中,内存管理至关重要。本文详细介绍了如何安全地清理系统缓存,特别是通过使用`/proc/sys/vm/drop_caches`接口。内容包括清理缓存的原因、步骤、注意事项和最佳实践,帮助你在必要时优化系统性能。
508 78
|
10月前
|
缓存 应用服务中间件 nginx
成功解决 Nginx更新静态资源无效 ,Nginx静态资源更新不及时,Nginx清除缓存
这篇文章讨论了在使用Nginx进行动静分离时遇到的静态资源更新不及时的问题。问题描述了在服务器上更新静态资源后,访问页面时页面没有显示更新的情况。文章提供了解决这个问题的方法,即清除浏览器缓存,并提供了相关参考文章链接。此外,还展示了问题复现的步骤和正常情况的预期结果。
成功解决 Nginx更新静态资源无效 ,Nginx静态资源更新不及时,Nginx清除缓存
|
8月前
|
缓存 Java Shell
Android 系统缓存扫描与清理方法分析
Android 系统缓存从原理探索到实现。
282 15
Android 系统缓存扫描与清理方法分析
|
8月前
|
Kubernetes 监控 测试技术
k8s学习--基于Ingress-nginx实现灰度发布系统
k8s学习--基于Ingress-nginx实现灰度发布系统
267 2
k8s学习--基于Ingress-nginx实现灰度发布系统
|
8月前
|
存储 缓存 监控
|
8月前
|
存储 缓存 负载均衡
Nginx代理缓存机制
【10月更文挑战第2天】
219 4
|
8月前
|
存储 缓存 NoSQL
Nginx缓存
Nginx缓存
70 2

热门文章

最新文章