架构设计 - Nginx Proxy Cache 缓存配置

摘要:

web 应用业务缓存通常3级:

一级缓存:JVM 本地缓存

二级缓存:Redis集中式缓存

三级缓存:Nginx Proxy Cache 缓存 或 Nginx Lua 缓存

四级缓存:静态资源CDN缓存

本文主要分享 Nginx Proxy Cache 缓存

缓存方式举例 配置 nginx.conf 文件

Lua 复制代码
    ......
    # 配置cache缓存节点 levels可以有2级目录 key2_zone键值对存储区域 inactive文件有效期 max_size文件容量
	proxy_cache_path /data/nginx/tmp-test levels=1:2 keys_zone=tmp-test:100m inactive=7d max_size=10g;
	
    # 配置https访问
    server {
		listen  8443 ssl;
		server_name order.abc.com;
        
        ssl_certificate /data/order/fullchain.pem;
        ssl_certificate_key /data/order/privkey.pem;
        ssl_session_timeout 1d;
        ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
        ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:HIGH:!aNULL:!MD5:!RC4:!DHE;
        ssl_prefer_server_ciphers on;
        
        location / {
            #将IP和端口改为DataEase服务器的访问地址和端口
            proxy_pass   http://172.16.16.16:9995/;
            server_name_in_redirect off;
			# 缓存节点
			proxy_cache tmp-test;
			proxy_cache_key $request_uri;
			# 只有请求返回以下状态码才会缓存 有效期是7天
			proxy_cache_valid 200 206 304 302 7d;
            # websocket 代理
            proxy_http_version      1.1;
            proxy_set_header        Upgrade         $http_upgrade;
            proxy_set_header        Connection "upgrade";

            proxy_redirect             http:// https://;
            proxy_set_header           Host $host:$server_port;
            proxy_set_header           X-Real-IP $remote_addr;
            proxy_set_header           X-Forwarded-For $proxy_add_x_forwarded_for;
            proxy_set_header           X-Forwarded-Proto $scheme;
        }
    }
......

实际项目应用

在Nginx端配置proxy cache缓存节点并非不常见,但在某些场景下可能会较少使用,这主要取决于特定的使用场景和配置需求。以下是一些可能导致这种情况的原因:

资源考虑

  • 内存和磁盘空间:配置proxy cache需要分配一定的内存(用于缓存元数据)和磁盘空间(用于存储实际缓存内容)。如果服务器资源有限,或者不希望将过多资源用于缓存,可能会选择不配置或配置较小的缓存。
  • 性能考虑:虽然缓存可以提高性能,但过多的缓存数据也可能导致缓存失效、查找和更新等操作的性能下降。

数据源特性

  • 动态内容:对于经常变动的动态内容,如实时数据、用户信息等,配置缓存可能不是最佳选择,因为缓存内容很快就会过时。
  • 第三方服务:当Nginx代理的是第三方服务时,可能由于服务协议、响应头或其他因素导致缓存策略不易控制或无效。

配置复杂性

  • 配置细节 :Nginx的proxy cache配置相对复杂,需要考虑多个指令和参数,如proxy_cache_pathproxy_cacheproxy_cache_valid等,这可能会增加配置和管理的复杂性。
  • 缓存失效:缓存失效策略需要根据实际情况进行配置,如基于时间、请求次数等,这可能需要额外的考虑和配置。

默认行为

  • Nginx默认不缓存:Nginx默认不会为代理的请求启用缓存,这可能是因为Nginx希望将缓存控制权留给用户或后端服务器。

其他缓存策略

  • CDN缓存:在实际应用中,可能会使用CDN(内容分发网络)进行缓存,CDN通常具有更丰富的缓存策略和功能,可以更有效地处理缓存相关问题。
  • 应用层缓存:有些应用可能会在自己的代码中实现缓存逻辑,以更直接地控制缓存内容和行为。
  • Nignx Lua缓存:以高效的协程机制可以实现远超过 Nginx Proxy Cache 的效果。Nginx Proxy Cache还是以读取/写入磁盘文件的方式来实现数据缓存,速度和效率与内存相比相差很多。

安全性考虑

  • 缓存敏感数据可能会带来安全风险,因此,在某些情况下,为了避免敏感数据的泄露,可能会选择不配置或谨慎配置Nginx的proxy cache。

综上所述,是否在Nginx端配置proxy cache缓存节点取决于多种因素,包括资源考虑、数据源特性、配置复杂性、默认行为、其他缓存策略以及安全性考虑等。在实际应用中,需要根据具体情况进行权衡和选择。

相关推荐
Chan165 分钟前
SpringAI:RAG 最佳实践与调优
java·spring boot·ai·java-ee·intellij-idea·rag·springai
odng6 分钟前
Windsurf / Codex 默认只显示 3 个最近任务,如何改成 100 个
java
m0_716765237 分钟前
C++巩固案例--通讯录管理系统详解
java·开发语言·c++·经验分享·学习·青少年编程·visual studio
Predestination王瀞潞9 分钟前
Java EE3-我独自整合(第三章:Spring DI 入门案例)
java·spring·java-ee
Ttang2311 分钟前
Java爬虫:Jsoup+OkHttp实战指南
java·爬虫·okhttp
李庆政37012 分钟前
OkHttp的基本使用 实现GET/POST请求 authenticator自动认证 Cookie管理 请求头设置
java·网络协议·http·okhttp·ssl
Chan1615 分钟前
SpringAI:MCP 协议介绍与接入方法
java·人工智能·spring boot·spring·java-ee·intellij-idea·mcp
zfoo-framework16 分钟前
[推荐]使用docker compose快速部署本地SpringBoot dev环境自测
spring boot·docker·容器
dllxhcjla19 分钟前
苍穹外卖2
java
迷藏49421 分钟前
**发散创新:Go语言中基于上下文的优雅错误处理机制设计与实战**在现代后端开发中,**错误处理**早已不是简单
java·开发语言·后端·python·golang