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

反向代理缓存能用吗?先看 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 应用在离线状态下也能正常运行。
- 下一篇
- Workerman版本过低怎么解决?升级PHP8.1以上即可
-
- 文章 · php教程 | 7分钟前 |
- 宝塔WebHook自动清理缓存教程
- 222浏览 收藏
-
- 文章 · php教程 | 9分钟前 |
- PHP判断中文标点及字符串长度方法
- 472浏览 收藏
-
- 文章 · php教程 | 13分钟前 | PHP字符串
- PHP全角转半角方法总结
- 329浏览 收藏
-
- 文章 · php教程 | 19分钟前 |
- PHP创建文件上传目录教程
- 439浏览 收藏
-
- 文章 · php教程 | 40分钟前 |
- PHP生成UUID的替代方案详解
- 458浏览 收藏
-
- 文章 · php教程 | 52分钟前 |
- PHP二分查找算法详解与面试题解析
- 251浏览 收藏
-
- 文章 · php教程 | 52分钟前 |
- PHP替换配置文件方法详解
- 128浏览 收藏
-
- 文章 · php教程 | 53分钟前 |
- PHP用Trie树高效过滤敏感词方法
- 453浏览 收藏
-
- 文章 · php教程 | 1小时前 | php
- PHP操作音频文件常用库及NAudio使用方法
- 390浏览 收藏
-
- 文章 · php教程 | 1小时前 |
- PHP性能优化:opcache启用与配置详解
- 276浏览 收藏
-
- 文章 · php教程 | 1小时前 |
- PHP框架工具隐错方法详解
- 361浏览 收藏
-
- 文章 · php教程 | 1小时前 |
- PHP替换字符串内容方法_str_replace使用教程
- 429浏览 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 485次学习
-
- ChatExcel酷表
- ChatExcel酷表是由北京大学团队打造的Excel聊天机器人,用自然语言操控表格,简化数据处理,告别繁琐操作,提升工作效率!适用于学生、上班族及政府人员。
- 4224次使用
-
- Any绘本
- 探索Any绘本(anypicturebook.com/zh),一款开源免费的AI绘本创作工具,基于Google Gemini与Flux AI模型,让您轻松创作个性化绘本。适用于家庭、教育、创作等多种场景,零门槛,高自由度,技术透明,本地可控。
- 4578次使用
-
- 可赞AI
- 可赞AI,AI驱动的办公可视化智能工具,助您轻松实现文本与可视化元素高效转化。无论是智能文档生成、多格式文本解析,还是一键生成专业图表、脑图、知识卡片,可赞AI都能让信息处理更清晰高效。覆盖数据汇报、会议纪要、内容营销等全场景,大幅提升办公效率,降低专业门槛,是您提升工作效率的得力助手。
- 4463次使用
-
- 星月写作
- 星月写作是国内首款聚焦中文网络小说创作的AI辅助工具,解决网文作者从构思到变现的全流程痛点。AI扫榜、专属模板、全链路适配,助力新人快速上手,资深作者效率倍增。
- 6113次使用
-
- MagicLight
- MagicLight.ai是全球首款叙事驱动型AI动画视频创作平台,专注于解决从故事想法到完整动画的全流程痛点。它通过自研AI模型,保障角色、风格、场景高度一致性,让零动画经验者也能高效产出专业级叙事内容。广泛适用于独立创作者、动画工作室、教育机构及企业营销,助您轻松实现创意落地与商业化。
- 4832次使用
-
- PHP技术的高薪回报与发展前景
- 2023-10-08 501浏览
-
- 基于 PHP 的商场优惠券系统开发中的常见问题解决方案
- 2023-10-05 501浏览
-
- 如何使用PHP开发简单的在线支付功能
- 2023-09-27 501浏览
-
- PHP消息队列开发指南:实现分布式缓存刷新器
- 2023-09-30 501浏览
-
- 如何在PHP微服务中实现分布式任务分配和调度
- 2023-10-04 501浏览

