要让数十个站点各自拥有独立、可维护的 proxy_cache 配置,需采用模块化拆分:按站隔离缓存区、动态加载配置文件、职责分明;每个站点独享 keys_zone 和缓存路径,通过 include 统一加载;用 map 基于 $host 区分 cache_zone 实现键隔离;再结合 if 或 map 动态 bypass 敏感路径与未登录请求。
要让数十个站点各自拥有独立、可维护的 proxy_cache 配置,不能把所有缓存逻辑堆在 nginx.conf 里,得靠模块化拆分——核心是“按站隔离 + 动态加载 + 职责分明”。
每个站点对应一个专属缓存区(keys_zone),路径、大小、过期策略都分开,避免混用和冲突。比如:
site_a、site_b…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 块顶部。宝塔面板的站点配置文件(server 块)里不写完整缓存指令,只做轻量接入:
include /www/server/nginx/conf/proxy_cache_rules/site_a.conf;
site_a.conf 文件里只放该站专用逻辑:cache zone 名、cache_key 构造、valid 规则、bypass 条件等;避免不同站点因相同 URI(如 /api/user)误共享缓存,必须让 cache_key 带站点标识:
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";
精细化控制不是全站开或关,而是按需跳过:
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;