CDN 如何实现同名文件的同步更新

2015-11-13 14:41:21 +08:00
 Jacklee

RT ,现在网站的静态资源都已经接入 CDN ,问题就是,有些文件( JS 、 CSS 、图片等)需要修改,修改完成后,如何做到同名(不修改文件名)文件上传后实时 CDN 同步更新到最新版本,而不是读取缓存内的资源呢。目前有在资源 url 加版本号参数的方法,每次更新需要换版本号,但是依然需要修改代码。所以寻求更好的,方便开发的方案。多谢大神

4487 次点击
所在节点    问与答
12 条回复
kikyous
2015-11-13 14:48:22 +08:00
/build/css/app-71cab977.css
请使用带校验码的文件名
kendetrics
2015-11-13 14:55:54 +08:00
你的 CDN 没有刷新缓存的 API 么
Jacklee
2015-11-13 15:48:57 +08:00
@kendetrics 有的。所以做一个手动刷新工具?都是这么做的么?
Jacklee
2015-11-13 15:49:21 +08:00
@kikyous 这样的话,文件名还是要修改呢
SharkIng
2015-11-13 15:56:32 +08:00
使用 gulp 管理前端这些东西是不是更方便些?
9hills
2015-11-13 15:58:53 +08:00
不是标准的都是 xxx.js?v=123123 这种么,至于 cache 机制, CDN 应该自己处理,不需要人工上传吧
Jacklee
2015-11-13 17:07:59 +08:00
@SharkIng 啊。又看到一个专业的工具,容我研究研究,谢谢
Jacklee
2015-11-13 17:11:01 +08:00
@9hills 恩,我看好多都是这样做,这样的话,其实每次更新文件,引用地址后面的参数 v 要改一下。前端觉得还是要上一遍代码(测服到正服中间步骤较多),觉得繁琐~~
helone
2015-11-13 17:14:54 +08:00
最简单的全部后面都带一个变量
例如: main.css?v=1.0

稍微复杂点的后面带上文件的 hash 值
例如: main.css?v=64c0d70b1e7e75da

再复杂点的每次独立编译一个文件,也保留旧版文件
例如: main-64c0d70b1e7e75da.css
9hills
2015-11-13 17:19:25 +08:00
@Jacklee 这个 v 应该是框架自动生成的,而不是写到代码里的。

是每次生成页面的时候生成的。
Jacklee
2015-11-13 18:25:36 +08:00
@helone 恩,这确实是一个比较通用的方法,现在就是想问问,关于这个变量能做到自动修改么(对应文件有更新时)?
Jacklee
2015-11-13 18:26:15 +08:00
@9hills 框架还支持这个啊?是如何检测对应的文件更新过呢

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/235948

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX