宝塔面板开启缓存提升网站速度
时间:2026-05-10 22:13:40 412浏览 收藏
宝塔面板中真正实现动态网页(如WordPress首页、Typecho文章页)的页面级缓存,关键不在于“静态文件缓存”开关或CDN回源设置,而需通过“网站→设置→反向代理”手动启用并精准配置Nginx的`proxy_cache`规则——包括正确设定`proxy_cache_key`、强制忽略`Set-Cookie`和`Cache-Control`响应头、排除登录/后台等动态路由,并警惕缓存穿透与stale响应导致的更新延迟;稍有不慎,就可能让所有用户看到同一份带他人登录信息的HTML,因此配置前必须清醒判断内容是否真正可缓存,否则再完美的规则也是一颗定时炸弹。

宝塔面板里哪个开关管页面缓存
页面缓存不是靠“网站设置”里那个“静态文件缓存”开关——它只管 .js、.css、.png 这类资源,不缓存 HTML 本身。真要缓存动态生成的页面(比如 WordPress 首页、Typecho 文章页),得用 Nginx 的 proxy_cache 或 Apache 的 mod_cache,而宝塔默认只暴露了前者配置入口。
实操路径是:网站 → 设置 → 反向代理 → 开启反向代理 → 在配置框里手写缓存规则。别点“缓存”选项卡里的“开启缓存”,那个是给 CDN 回源用的,对本地页面无效。
- 必须先启用反向代理(哪怕没真实后端,指向本机
127.0.0.1:8080也行) - 缓存目录默认在
/www/server/nginx/proxy_cache_dir,确保磁盘有空间且 Nginx 有写权限 - 宝塔 8.x 后版本才支持在反代配置里直接加
proxy_cache块,老版本需手动改nginx.conf
缓存 HTML 页面必须写的 Nginx 配置片段
光开开关没用,关键在配置里是否命中响应头和 URL 规则。常见错误是缓存了带 Cookie 的页面,导致用户 A 看到用户 B 的后台页。
以下是最简可用的 location 块(贴进反向代理配置框):
proxy_cache cache_one; proxy_cache_valid 200 301 302 10m; proxy_cache_valid any 1m; proxy_cache_key $scheme$host$request_uri$is_args$args; proxy_ignore_headers Cache-Control Expires Set-Cookie; proxy_hide_header X-Powered-By;
proxy_ignore_headers Cache-Control:强制忽略 PHP 输出的Cache-Control: no-cache,否则缓存永远不生效- 删掉
Set-Cookie是必须的——否则登录态、购物车会串,尤其 WordPress 必须加这行 $request_uri$is_args$args比$uri更准,能区分/post/123和/post/123?utm_source=weibo
为什么刷新页面没变 / 缓存不更新
不是缓存没起作用,而是你触发了 Nginx 的“缓存穿透”保护:当后端返回 502/504 时,Nginx 默认会把旧缓存继续吐给用户,造成“页面卡在旧状态”。另外,proxy_cache_valid 时间一过,Nginx 不会主动删缓存,而是等下次请求时发现过期再回源校验(叫 stale),所以你看到的“没更新”其实是 stale 响应。
- 临时清缓存:运行
rm -rf /www/server/nginx/proxy_cache_dir/*,然后nginx -s reload - 想让更新立刻生效,加
proxy_cache_use_stale error timeout updating http_500 http_502 http_503 http_504; - 开发调试时,在浏览器地址栏加
?t=xxx参数,因为$request_uri包含参数,就绕开了缓存键
WordPress / Typecho 等 CMS 的特殊注意点
这类程序常在 HTML 里硬编码时间、随机数或用户 ID,缓存后所有用户看到同一份 HTML,结果首页显示“欢迎,张三”,但李四打开也是“张三”。
根本解法不是关缓存,而是拆分动态块:
- 用
ngx_http_sub_module替换 HTML 中的用户名(需编译进 Nginx,宝塔默认不含) - 更现实的做法:用插件(如 WP Super Cache)做服务端页面缓存,它生成真实
.html文件,不依赖 Nginx proxy_cache - 如果坚持用宝塔 proxy_cache,至少把用户相关路由排除,例如加
location ~ ^/(wp-admin|wp-login\.php|wp-json) { proxy_cache off; }
缓存 HTML 最容易翻车的地方,从来不是配置写错,而是没意识到“页面内容是否真的可缓存”。一个 Set-Cookie 头、一段 JS 时间戳、一次未声明的 AJAX 请求,都可能让缓存变成定时炸弹。
理论要掌握,实操不能落!以上关于《宝塔面板开启缓存提升网站速度》的详细介绍,大家都掌握了吧!如果想要继续提升自己的能力,那么就来关注golang学习网公众号吧!
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
215 收藏
-
282 收藏
-
345 收藏
-
308 收藏
-
109 收藏
-
384 收藏
-
334 收藏
-
176 收藏
-
412 收藏
-
316 收藏
-
219 收藏
-
437 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习