当前位置:首页 > 文章列表 > 文章 > php教程 > 宝塔面板反向代理缓存配置技巧

宝塔面板反向代理缓存配置技巧

2026-03-30 14:39:59 0浏览 收藏
宝塔面板虽支持反向代理缓存,但实际启用需绕过图形界面的限制:首先确认Nginx已编译ngx_http_proxy_cache_module模块(宝塔8.x默认具备,自定义编译易缺失),缺失时应通过软件商店勾选“Proxy Cache”重装Nginx;接着必须在全局http块中配置proxy_cache_path,再于站点配置的location内调用proxy_cache及相关指令,而非直接写在反向代理自动生成的配置中;同时需谨慎选择可缓存的API路径(避开含用户身份、实时性高或禁用缓存的响应),合理设置缓存键、忽略敏感头、添加绕过机制,并通过日志(如upstream_cache_status)和磁盘文件验证真实命中情况——因为看似启用的缓存,常因权限、磁盘空间、inactive时间或Vary头等细节问题悄然失效。

如何利用宝塔面板配置反向代理缓存_提升API访问性能

反向代理缓存能用吗?先看 Nginx 版本和模块

宝塔面板底层用的是 Nginx,但默认安装的 nginx 很可能没编译 ngx_http_proxy_cache_module —— 这个模块是反向代理缓存的基础设施。直接配了也无效,连 proxy_cache_path 都会报 unknown directive "proxy_cache_path"

检查方法:nginx -V 2>&1 | grep -o with-http_proxy_cache_module。没输出就说明缺失。

  • 宝塔 8.x 默认 Nginx 1.22+ 多数已内置,但「极速编译」或「自定义编译」安装的容易漏掉
  • 如果缺失,别折腾源码重编,直接在宝塔「软件商店 → Nginx → 设置 → 编译安装」里勾选「Proxy Cache」再重装更稳
  • 注意:重装 Nginx 会清空你手动写的 nginx.conf 全局配置,缓存路径等必须在重装后重新加到「配置修改」页顶部

缓存配置写在哪?不是在站点配置里随便贴

宝塔的「反向代理」功能本身不支持缓存指令,它只生成基础 proxy_pass。想用缓存,必须绕过图形界面,在 Nginx 全局配置里定义缓存区,再在具体站点的「配置修改」中调用。

常见错误是把 proxy_cache_path 直接塞进站点配置的 location 块里——Nginx 会报错,因为该指令只能出现在 http 块顶层。

  • 正确位置:宝塔 → Nginx → 「配置修改」→ 找到 http { 开头处,在其下第一行添加:
    proxy_cache_path /www/server/nginx/proxy_cache levels=1:2 keys_zone=api_cache:10m max_size=1g inactive=30m use_temp_path=off;
  • 然后在目标站点的「配置修改」→ 「反向代理」生成的配置段里,location 内补上:
    proxy_cache api_cache;
    proxy_cache_valid 200 302 10m;
    proxy_cache_use_stale error timeout updating http_500 http_502 http_503 http_504;
  • 特别注意:keys_zone 名称(这里是 api_cache)必须前后一致,大小写敏感

哪些 API 能缓存?别让敏感数据进磁盘

缓存不是万能加速器。对带用户身份、实时性要求高、或返回头含 Cache-Control: no-store 的 API,硬上缓存反而导致数据错乱或泄露。

典型不能缓存的场景:/user/profile(含 token 或 session)、/order/status(需秒级更新)、所有 POST/PUT/DELETE 请求(Nginx 默认不缓存非 GET/HEAD)。

  • 强制只缓存特定路径:用 location ~ ^/api/v1/public/ 替代泛匹配 location /
  • 绕过缓存的请求,加 proxy_cache_bypass $http_cache_control $arg_nocache;,前端加 ?nocache=1 就能临时穿透
  • 响应头里有 Set-Cookie 的,Nginx 默认不缓存;如确需缓存,得加 proxy_ignore_headers Set-Cookie;,但要确认业务无状态
  • 缓存键默认包含 Host + URI + 参数,如需忽略某参数(比如 utm_source),得用 proxy_cache_key 自定义

缓存生效了吗?别只看响应头里的 X-Proxy-Cache

宝塔默认不会自动加 X-Proxy-Cache 头,光靠浏览器 Network 面板看不出是否命中。得自己加日志或查磁盘文件。

更麻烦的是:缓存目录权限不对、磁盘满、或 inactive 时间设太短,都会让缓存“看似启用实则失效”。

  • 验证缓存写入:ls -l /www/server/nginx/proxy_cache/,有子目录且非空说明路径生效
  • 加临时日志:在站点配置的 location 块里加 log_format cache '$remote_addr - $upstream_cache_status [$time_local] "$request" $status $body_bytes_sent';,再用 access_log /www/wwwlogs/cache.log cache;
  • 关键指标看 HIT / MISS / BYPASS,而不是只盯 200 状态码
  • 首次访问必 MISS,第二次才可能 HIT;但若上游响应头带 Vary: Authorization,即使同一 URL 也会因 header 不同而分存多份,容易误判为未命中

缓存路径的磁盘空间和 inode 数量,比响应速度更容易成为瓶颈。尤其是大量小响应体(如 JSON API),levels=1:2 能缓解,但得定期 find /www/server/nginx/proxy_cache -type f -mmin +60 -delete 配合清理脚本。

今天带大家了解了的相关知识,希望对你有所帮助;关于文章的技术知识我们会一点点深入介绍,欢迎大家关注golang学习网公众号,一起学习编程~

Service Worker 是 JavaScript 的一种后台脚本,它运行在浏览器的后台,独立于网页,可以拦截和处理网络请求,实现离线应用功能。通过缓存资源,Service Worker 可以在没有网络连接时提供已缓存的内容,从而让 Web 应用在离线状态下也能正常运行。Service Worker 是 JavaScript 的一种后台脚本,它运行在浏览器的后台,独立于网页,可以拦截和处理网络请求,实现离线应用功能。通过缓存资源,Service Worker 可以在没有网络连接时提供已缓存的内容,从而让 Web 应用在离线状态下也能正常运行。
上一篇
Service Worker 是 JavaScript 的一种后台脚本,它运行在浏览器的后台,独立于网页,可以拦截和处理网络请求,实现离线应用功能。通过缓存资源,Service Worker 可以在没有网络连接时提供已缓存的内容,从而让 Web 应用在离线状态下也能正常运行。
Workerman版本过低怎么解决?升级PHP8.1以上即可
下一篇
Workerman版本过低怎么解决?升级PHP8.1以上即可
查看更多
最新文章
查看更多
课程推荐
  • 前端进阶之JavaScript设计模式
    前端进阶之JavaScript设计模式
    设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
    543次学习
  • GO语言核心编程课程
    GO语言核心编程课程
    本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
    516次学习
  • 简单聊聊mysql8与网络通信
    简单聊聊mysql8与网络通信
    如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
    500次学习
  • JavaScript正则表达式基础与实战
    JavaScript正则表达式基础与实战
    在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
    487次学习
  • 从零制作响应式网站—Grid布局
    从零制作响应式网站—Grid布局
    本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
    485次学习
查看更多
AI推荐
  • ljg-skills -
    ljg-skills
    ljg-skills 是李继刚开源的 AI 技能与提示词集合,面向大模型使用者整理了一批可复用的 prompt、角色设定和任务技能模板,适合用于学习提示词设计、搭建个人 AI 工作流和沉淀团队常用智能体能力。
    291次使用
  • MELO音乐 - AI 音乐生成平台,支持多模态创作能力
    MELO音乐
    MELO音乐是一站式AI视频与音乐制作助手,对标suno, udio的高品质体验。提供伴奏生成、原创写词、无损导出、哼唱识曲、混音变声等全套音频与短视频编辑工具。无论是流行Kpop、电音说唱、民谣古风、摇滚儿歌还是商用轻音乐,MELO为你免费谱曲,轻松做同款!
    306次使用
  • UniScribe - AI 免费在线音视频转文字平台
    UniScribe
    UniScribe 是一款 AI 音视频转文字与内容整理工具,支持上传音频、视频文件或粘贴 YouTube 链接,自动生成转写文本、摘要、思维导图和关键问题,并支持多格式导出,适合会议记录、课程学习、访谈整理和内容创作复盘。
    277次使用
  • 剧云 - 免费 AI 智能中文剧本创作平台
    剧云
    剧云是专业中文剧本创作平台,安全稳定运行十余年,集成AI编剧、剧本医生审核、人物小传、剧情关系图、大纲编写、多人协作、Word导入导出、版权管控功能,数据安全防护,轻松高效创作剧本。
    451次使用
  • 万象有声 - AI 一站式有声内容创作平台
    万象有声
    万象有声,一个专为有声创作者打造的新一代智能有声内容创作平台。平台提供专业的智能拆章、智能画本编辑、AI配音、AI生成音效、后期制作、智能对轨、智能审听等有声创作全流程工具,可以帮助创作者高效、低成本创作出引人入胜的有声作品。立即体验,让有声书制作更简单!
    437次使用
微信登录更方便
  • 密码登录
  • 注册账号
登录即同意 用户协议隐私政策
返回登录
  • 重置密码