当前位置:首页 > 文章列表 > 文章 > php教程 > CDN配置与浏览器缓存实战教程

CDN配置与浏览器缓存实战教程

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

静态资源加速:CDN配置与浏览器缓存策略实战

如果您已部署网站但静态资源(如 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学习网公众号了解相关技术文章。

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