如何通过模块化拆分 proxy_cache 配置文件实现数十个不同站点的缓存精细化隔离

作者:袖梨 2026-06-19
要让数十个站点各自拥有独立、可维护的 proxy_cache 配置,需采用模块化拆分:按站隔离缓存区、动态加载配置文件、职责分明;每个站点独享 keys_zone 和缓存路径,通过 include 统一加载;用 map 基于 $host 区分 cache_zone 实现键隔离;再结合 if 或 map 动态 bypass 敏感路径与未登录请求。

要让数十个站点各自拥有独立、可维护的 proxy_cache 配置,不能把所有缓存逻辑堆在 nginx.conf 里,得靠模块化拆分——核心是“按站隔离 + 动态加载 + 职责分明”。

为每个站点单独建缓存区定义文件

每个站点对应一个专属缓存区(keys_zone),路径、大小、过期策略都分开,避免混用和冲突。比如:

  • 在 /www/server/nginx/proxy_cache/ 下为每个站点建子目录:site_asite_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;
  • 敏感路径、未登录用户、后台接口自动不进缓存,其余正常缓存。

相关文章

精彩推荐