CDN配置与浏览器缓存实战教程
时间:2026-05-11 08:21:57 458浏览 收藏
本文深入解析了静态资源加载缓慢的五大实战优化策略:通过独立CDN域名接入与回源配置实现地理就近分发;利用Nginx精细化设置1年有效期+immutable缓存头,确保浏览器与中间代理高效复用;借助构建工具(Webpack/Vite等)自动将资源URL切换至CDN域名,真正打通加速链路;在CDN控制台按文件类型分级配置缓存TTL(如静态资源30天、HTML/PHP不缓存),兼顾性能与实时性;最后叠加Nginx本地proxy_cache层,缓解回源压力并提升后端响应效率——五步环环相扣,从边缘到源站构建全链路缓存体系,助你显著降低首屏时间、释放源站带宽、提升用户体验。

如果您已部署网站但静态资源(如 CSS、JS、图片、字体)加载缓慢,页面首屏时间偏高,则很可能是源站直连导致的网络延迟与带宽瓶颈。以下是实现静态资源加速的多种配置路径:
一、CDN 域名接入与回源配置
该方法通过将静态资源托管至 CDN 边缘节点,使用户从地理最近的服务器获取内容,显著降低 RTT 并分担源站压力。需确保 CDN 加速域名独立于主站域名(例如 static.example.com),并正确指向源站 Nginx。
1、登录 CDN 服务商控制台(如阿里云 CDN、腾讯云 CDN 或 Cloudflare),进入「域名管理」→「添加域名」。
2、填写加速域名(如 static.example.com),选择加速区域(中国大陆需已完成 ICP 备案)。
3、设置源站信息:填写 Nginx 服务器公网 IP 或主域名(如 example.com),启用「强制 HTTPS 回源」。
4、完成域名所有权验证:按提示在 DNS 解析平台添加指定 TXT 记录,等待控制台显示「已验证」。
5、获取 CDN 分配的 CNAME 地址(如 static.example.com.w.kunlungr.com),在 DNS 中为加速域名添加 CNAME 记录并保存。
二、Nginx 静态资源缓存头精细化设置
此步骤确保浏览器与中间代理(包括 CDN 节点)能正确识别资源的不可变性,避免重复请求。关键在于为不同资源类型设置匹配其更新频率的 Cache-Control 与 expires 指令。
1、编辑 Nginx server 块配置文件(如 /etc/nginx/conf.d/example.conf)。
2、插入以下 location 块(置于 root 指令同级):
location ~* \.(js|css|png|jpg|jpeg|gif|ico|svg|woff2|ttf|eot|webp|pdf|xml|txt)$ {
expires 1y;
add_header Cache-Control "public, immutable";
add_header X-Content-Type-Options nosniff;
try_files $uri =404;
}
3、确认该 location 不被其他 rewrite 或 proxy_pass 规则覆盖,执行 nginx -t && nginx -s reload 重载配置。
三、前端资源链接自动切换至 CDN 域名
若 HTML、CSS 或 JS 中仍引用 /static/logo.png 等相对或源站绝对路径,用户请求仍将绕过 CDN。必须将所有静态资源 URL 替换为 CDN 加速域名,才能触发边缘缓存。
1、Webpack 项目:在 webpack.config.js 中设置 output.publicPath: 'https://static.example.com/'。
2、Vite 项目:在 vite.config.ts 中配置 base: 'https://static.example.com/'。
3、Egg.js 项目:修改 config/config.default.js 中 siteFile 配置,将字符串值设为 CDN 地址(如 '/logo.png': 'https://static.example.com/logo.png')。
4、无法修改构建流程时(如传统 PHP 站点),可在 Nginx 中添加临时重写规则(不推荐长期使用):
rewrite ^/(static|assets|dist)/(.*)$ https://static.example.com/$2 permanent;
四、CDN 缓存规则分级配置
CDN 控制台中的缓存规则决定边缘节点如何存储与刷新资源。应按文件类型设置差异化 TTL,避免动态资源被错误缓存,同时保障静态资源长期有效。
1、进入 CDN 控制台「缓存配置」→「新增缓存规则」。
2、添加第一条规则:匹配文件类型 .js;.css;.woff2;.ttf;.png;.jpg;.webp;.gif;.ico;.svg,缓存时间设为 30天。
3、添加第二条规则:匹配路径前缀 /zb_users/upload/(Z-Blog 用户上传目录),缓存时间设为 30天。
4、添加第三条规则:匹配文件类型 .php;.html;.htm,缓存时间设为 0秒(即不缓存)。
5、保存后,在控制台「刷新预热」中手动提交关键资源 URL 进行首次预热(如 https://static.example.com/main.css)。
五、Nginx 本地磁盘缓存(proxy_cache)增强回源效率
当 CDN 节点缓存失效并发起回源请求时,Nginx 可自身缓存响应结果,减少对后端应用(如 PHP-FPM 或 Node.js)的重复调用,提升回源吞吐能力。
1、在 http 块顶部添加缓存路径定义:
proxy_cache_path /var/cache/nginx levels=1:2 keys_zone=my_cache:10m inactive=60m use_temp_path=off;
2、在 server 块内新增 location 块:
location ~* \.(js|css|png|jpg|gif|webp|woff2|ttf)$ {
proxy_cache my_cache;
proxy_cache_valid 200 304 1h;
proxy_cache_use_stale error timeout updating http_500 http_502 http_503 http_504;
proxy_pass http://127.0.0.1:8080; # 指向后端应用服务
add_header X-Cache-Status $upstream_cache_status;
}
3、创建缓存目录并赋权:mkdir -p /var/cache/nginx && chown www-data:www-data /var/cache/nginx。
文中关于的知识介绍,希望对你的学习有所帮助!若是受益匪浅,那就动动鼠标收藏这篇《CDN配置与浏览器缓存实战教程》文章吧,也可关注golang学习网公众号了解相关技术文章。
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
175 收藏
-
368 收藏
-
219 收藏
-
154 收藏
-
291 收藏
-
427 收藏
-
298 收藏
-
421 收藏
-
413 收藏
-
187 收藏
-
331 收藏
-
119 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习