最新下载
热门教程
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
如何通过模块化拆分 proxy_cache 配置文件实现数十个不同站点的缓存精细化隔离
时间:2026-06-19 09:12:52 编辑:袖梨 来源:一聚教程网
要让数十个站点各自拥有独立、可维护的 proxy_cache 配置,需采用模块化拆分:按站隔离缓存区、动态加载配置文件、职责分明;每个站点独享 keys_zone 和缓存路径,通过 include 统一加载;用 map 基于 $host 区分 cache_zone 实现键隔离;再结合 if 或 map 动态 bypass 敏感路径与未登录请求。
要让数十个站点各自拥有独立、可维护的 proxy_cache 配置,不能把所有缓存逻辑堆在 nginx.conf 里,得靠模块化拆分——核心是“按站隔离 + 动态加载 + 职责分明”。
为每个站点单独建缓存区定义文件
每个站点对应一个专属缓存区(keys_zone),路径、大小、过期策略都分开,避免混用和冲突。比如:
- 在 /www/server/nginx/proxy_cache/ 下为每个站点建子目录:
site_a、site_b… - 在 /www/server/nginx/conf/proxy_cache/ 下创建对应配置文件:
site_a.conf内容为:proxy_cache_path /www/server/nginx/proxy_cache/site_a levels=1:2 keys_zone=site_a:50m max_size=5g inactive=1h use_temp_path=off; - 所有这类文件统一用
include /www/server/nginx/conf/proxy_cache/*.conf;加载到 http 块顶部。
用 include 把缓存策略绑定到具体站点配置中
宝塔面板的站点配置文件(server 块)里不写完整缓存指令,只做轻量接入:
- 在站点【配置文件】→ server 块内合适位置插入:
include /www/server/nginx/conf/proxy_cache_rules/site_a.conf; -
site_a.conf文件里只放该站专用逻辑:cache zone 名、cache_key 构造、valid 规则、bypass 条件等; - 这样改某个站的缓存行为,只需动它自己的规则文件,不影响其他站。
用 map + 变量实现跨站点缓存键隔离
避免不同站点因相同 URI(如 /api/user)误共享缓存,必须让 cache_key 带站点标识:
- 在全局 http 块中统一定义 map:
map $host $site_cache_zone {<br> example.com site_a;<br> blog.example.com site_b;<br> default no_cache;<br>} - 在各站点规则文件中写:
proxy_cache $site_cache_zone;<br>proxy_cache_key "$host$request_uri$args";
- 这样即使路径一样,host 不同就走不同缓存区,天然隔离。
按路径/请求特征动态绕过缓存
精细化控制不是全站开或关,而是按需跳过:
- 在站点规则文件里用 if 或 map 判断:
set $skip_cache 0;<br>if ($request_uri ~* "^/(admin|login|checkout)") { set $skip_cache 1; }<br>if ($cookie_user_id = "") { set $skip_cache 1; } - 再配:
proxy_cache_bypass $skip_cache;<br>proxy_no_cache $skip_cache;
- 敏感路径、未登录用户、后台接口自动不进缓存,其余正常缓存。
相关文章
- 明末渊虚之羽版本奖励错误如何补偿 07-01
- 原神峡谷盈月之镜解谜方法 07-01
- 末日进化如何升级人物卡 07-01
- 魔兽世界卡格罗什的命运背包位置在哪 07-01
- 沙石镇时光体力恢复方法大全 沙石镇时光快速回满体力的实用技巧 07-01
- 空洞骑士寻神者篇章攻略 07-01