当前位置:首页 > 文章列表 > 文章 > 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推荐
  • ChatExcel酷表:告别Excel难题,北大团队AI助手助您轻松处理数据
    ChatExcel酷表
    ChatExcel酷表是由北京大学团队打造的Excel聊天机器人,用自然语言操控表格,简化数据处理,告别繁琐操作,提升工作效率!适用于学生、上班族及政府人员。
    4224次使用
  • Any绘本:开源免费AI绘本创作工具深度解析
    Any绘本
    探索Any绘本(anypicturebook.com/zh),一款开源免费的AI绘本创作工具,基于Google Gemini与Flux AI模型,让您轻松创作个性化绘本。适用于家庭、教育、创作等多种场景,零门槛,高自由度,技术透明,本地可控。
    4578次使用
  • 可赞AI:AI驱动办公可视化智能工具,一键高效生成文档图表脑图
    可赞AI
    可赞AI,AI驱动的办公可视化智能工具,助您轻松实现文本与可视化元素高效转化。无论是智能文档生成、多格式文本解析,还是一键生成专业图表、脑图、知识卡片,可赞AI都能让信息处理更清晰高效。覆盖数据汇报、会议纪要、内容营销等全场景,大幅提升办公效率,降低专业门槛,是您提升工作效率的得力助手。
    4463次使用
  • 星月写作:AI网文创作神器,助力爆款小说速成
    星月写作
    星月写作是国内首款聚焦中文网络小说创作的AI辅助工具,解决网文作者从构思到变现的全流程痛点。AI扫榜、专属模板、全链路适配,助力新人快速上手,资深作者效率倍增。
    6113次使用
  • MagicLight.ai:叙事驱动AI动画视频创作平台 | 高效生成专业级故事动画
    MagicLight
    MagicLight.ai是全球首款叙事驱动型AI动画视频创作平台,专注于解决从故事想法到完整动画的全流程痛点。它通过自研AI模型,保障角色、风格、场景高度一致性,让零动画经验者也能高效产出专业级叙事内容。广泛适用于独立创作者、动画工作室、教育机构及企业营销,助您轻松实现创意落地与商业化。
    4832次使用
微信登录更方便
  • 密码登录
  • 注册账号
登录即同意 用户协议隐私政策
返回登录
  • 重置密码