- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
对于图片库,我必须使用 CDN。为此,我创建了一个子域
image.example.com
此子域通过 CNAME 指向 CDN URL。
旧图片路径:
http://www.example.com/files/thumbs
我将图库中的所有图片路径更改为:
http://images.example.com/files/thumbs
我需要一个来自
的301重定向http://www.example.com/files/thumbs
到
http://images.example.com/files/thumbs
我已经发了一篇关于这个的帖子。
Redirect folder to subdomain with folder
与 anubhava 协调,我现在打开一个新问题。
我试过这个:
RewriteCond %{HTTP_HOST} ^(?:www\.)?example\.com$ [NC]
RewriteRule ^(files/thumbs/.*)$ http://images.example.com/$1 [L,R=301,NC]
还有这个:
RewriteRule ^(files/thumbs/.*)$ http://images.example.com/$1 [L,R=301,NC]
两条规则都会导致:重定向过多/永无止境。
重要:
CDN 缓存图片后,一切正常。 CDN 需要 2 个请求,第三个请求是命中。当 CDN 没有命中(第一个或第二个请求)时,重定向不起作用。当 CDN 丢失文件时,本地服务器提供图像。有适合我需要的规则吗?
非常感谢
-----添加了有关问题的更多信息----
我们有两种情况 - HIT 和 MISS:
场景 1 - HIT
请检查以下步骤并注意 X-Cache 和顶部的 http 状态代码:
1. curl -I http://images.example.com/files/thumbs/my-cache-hitting-image.jpg
HTTP/1.1 200 OK
Date: Fri, 27 Mar 2015 07:37:10 GMT
Content-Type: image/jpeg
Content-Length: 14525
Connection: keep-alive
Last-Modified: Thu, 19 Mar 2015 12:44:39 GMT
Cache-Control: max-age=2592000
Expires: Sun, 26 Apr 2015 07:37:10 GMT
Vary: User-Agent
Server: NetDNA-cache/2.2
X-Cache: HIT
Accept-Ranges: bytes
现在我们检查正在运行的重定向(打开旧 url):
curl -I http://www.example.com/files/thumbs/my-cache-hitting-image.jpg
HTTP/1.1 301 Moved Permanently
Date: Fri, 27 Mar 2015 07:39:06 GMT
Server: Apache
Location: http://images.example.com/files/thumbs/my-cache-hitting-image.jpg
Vary: Accept-Encoding
Content-Type: text/html; charset=iso-8859-1
完美 - 完成!
场景 2 - 小姐
curl -I http://images.example.com/files/thumbs/my-cache-missing-image.jpg
HTTP/1.1 301 Moved Permanently
Date: Fri, 27 Mar 2015 07:41:27 GMT
Content-Type: text/html; charset=iso-8859-1
Content-Length: 278
Connection: keep-alive
Location: http://images.example.com/files/thumbs/my-cache-missing-image.jpg
Vary: Accept-Encoding
Server: NetDNA-cache/2.2
Expires: Sun, 26 Apr 2015 07:41:27 GMT
Cache-Control: max-age=2592000
X-Cache: MISS
Fazit:当有MISS时,会导致Loop,因为CDN把请求还给了源站,而源站是这样做的:
curl -I http://www.example.com/files/thumbs/my-cache-missing-image.jpg
HTTP/1.1 301 Moved Permanently
Date: Fri, 27 Mar 2015 07:26:13 GMT
Server: Apache
Location: http://images.example.com/files/thumbs/my-cache-missing-image.jpg
Vary: Accept-Encoding
Content-Type: text/html; charset=iso-8859-1
这是一个永无止境的循环。也许有一种方法可以通过 httaccess Cond 检查状态码?!
最佳答案
我找到了解决方法。也许任何人都需要它:
当我想要从旧的(索引的)url 重定向到 cdn url 并且 cdn 将它返回到也是旧 url 的原始 url 时,它当然会进入循环。
解决方案:创建一个不同的 URL,CDN 可以在其中捕获文件。因此,请执行以下操作:
Create a subdomain - Example:
catcher.example.com (normal A record)
Point this subdomain to your root directory of the website. Has to be the same directory as the original website directory.
Add catcher.example.com to the origin URL in your CDN Settings.
Add a rewrite cond that will force the redirect ONLY when there is OLD url and NOT from our catcher.example.com
RewriteCond %{REQUEST_URI} ^/files/thumbs
RewriteCond %{HTTP_HOST} ^www.example.com$
RewriteRule ^(files/thumbs/.*)$ http://images.example.com/$1 [L,R=301,NC]
(我需要第一个 RewriteCond 吗?)以防万一我添加了。
结果:不再有循环。因为这样 CDN 可以捕获来自 catcher.example.com 的文件和旧链接获得重定向到 apache 而不会导致循环。只要是具有相同目录路径的同一文件,CDN 可以从何处捕获该文件并不重要。
第一次测试成功。如果我错了,请指正。
关于.htaccess - 301重定向/所有图片到CDN,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29287374/
我正在尝试使用谷歌浏览器的 Trace Event Profiling Tool分析我正在运行的 Node.js 应用程序。选择点样本后,我可以在三种 View 之间进行选择: 自上而下(树) 自上而
对于一个可能是菜鸟的问题,我们深表歉意,但尽管在 SO 上研究了大量教程和其他问题,但仍找不到答案。 我想做的很简单:显示一个包含大量数据库存储字符串的 Android ListView。我所说的“很
我已经开始了一个新元素的工作,并决定给 Foundation 5 一个 bash,看看它是什么样的。在创建带有水平字段的表单时,我在文档中注意到的第一件事是它们使用大量 div 来设置样式。所以我在下
我有一个 Windows 窗体用户控件,其中包含一个使用 BeginInvoke 委托(delegate)调用从单独线程更新的第 3 方图像显示控件。 在繁重的 CPU 负载下,UI 会锁定。当我附加
我有一堆严重依赖dom元素的JS代码。我目前使用的测试解决方案依赖于 Selenium ,但 AFAIK 无法正确评估 js 错误(addScript 错误不会导致您的测试失败,而 getEval 会
我正在制作一款基于滚动 2D map /图 block 的游戏。每个图 block (存储为图 block [21][11] - 每个 map 总共 231 个图 block )最多可以包含 21 个
考虑到以下情况,我是前端初学者: 某个 HTML 页面应该包含一个沉重的图像(例如 - 动画 gif),但我不想强制客户缓慢地等待它完全下载才能享受一个漂亮的页面,而是我更愿意给他看一个轻量级图像(例
我正在设计一个小软件,其中包括: 在互联网上获取资源, 一些用户交互(资源的快速编辑), 一些处理。 我想使用许多资源(它们都列在列表中)来这样做。每个都独立于其他。由于编辑部分很累,我想让用户(可能
我想比较两个理论场景。为了问题的目的,我简化了案例。但基本上它是您典型的生产者消费者场景。 (我关注的是消费者)。 我有一个很大的Queue dataQueue我必须将其传输给多个客户端。 那么让我们
我有一个二元分类问题,标签 0 和 1(少数)存在巨大不平衡。由于测试集带有标签 1 的行太少,因此我将训练测试设置为至少 70-30 或 60-40,因此仍然有重要的观察结果。由于我没有过多地衡量准
我是一名优秀的程序员,十分优秀!