我正在尝试做一些应该相对简单的事情 - 我想设置一些域和子域来重定向到我们网站的核心域,但我想将重定向放在 Cloudfront 上。除了重定向根路径外,一切正常——这让我得到了一个部分描述 S3 存储桶的 XML 文件。
背景
S3
S3 允许您设置一个全重定向存储桶,例如:
对此进行测试,Web 端点 (brass9-com.s3-website-us-west-1.amazonaws.com) 做了它应该做的 - 它重定向到 bras9.com。好的。
云前
Cloudfront 允许您指向 S3 存储桶,但它建议您这样做的方式是错误的 -您需要使用上面的 Web 端点,而不是按其名称指向存储桶,如 bras9-com.s3.amazonaws.com 。除此之外,您可以将所有内容保留为默认值并获得良好的重定向行为。所以,像www.brass9.com/portfolio这样的路径会正确地重定向到它应该去的地方。也很好。
问题 - 根域重定向
然后无法工作的一件事是从普通的www.brass9.com重定向。它没有给你一个重定向,而是给你这个奇怪的结果:
<?xml version="1.0" encoding="UTF-8"?>
<ListBucketResult xmlns="http://s3.amazonaws.com/doc/2006-03-01/">
<Name>brass9-com</Name><Prefix></Prefix>
<Marker></Marker><MaxKeys>1000</MaxKeys><IsTruncated>false</IsTruncated>
</ListBucketResult>
好的... 。所以这并不完全出乎意料——因为没有默认根对象。但是我可能会指定什么默认根对象来防止这种行为?我需要指向的 S3 重定向对象(如果有)的名称是什么?还是有其他一些适当的配置,或者这只是 Amazon 需要修复的 Cloudfront 和 S3 交互方式中的一个错误?
已知不工作的解决方案:默认根对象
可以指定 index.html 的默认根对象,但它没有任何帮助 - 它只是改变了问题。Cloudfront url 而是重定向到主站点上的 /index.html,这是一个 404(我们不使用 index.html 文件,它是一个服务器端框架驱动的站点)。我可以在服务器上放置一个 index.html,但这首先会破坏使用 Cloudfront 的小速度增益。
类似问题
一个问题提出了类似的问题,但由于某种原因得到了一个空白的 0 字节响应,而不是我所看到的 XML 响应。它不包括有关该问题或解决方案的问题。
相关文章
一篇文章建议您只在裸域和 www 域上为整个站点提供服务。这与任何用户的书签、您的搜索排名等有关。您不应该这样做。
一些讨论在 S3 和 Cloudfront 上托管静态网站而不是重定向方案,因此是不相关的。
那么,我该如何正确地做到这一点?
Cloudfront 配置的屏幕截图 - 没有默认根对象,指向 S3 源。忽略 InProgress - 我刚刚打开和关闭默认根对象进行测试。
以及该发行版的 Origin 配置:
如果您遇到此问题,请在为云端配置 s3 存储桶源时首先检查,自动完成功能会返回 s3 REST 端点domain.amazonaws.com,它会返回此 ListBucketResult 响应。
您必须手动记下网站端点 domain.s3-website-region.amazonaws.com
重要提示:如果您错误地使用 REST 端点配置了云端,您必须通过 Invalidations 使缓存无效,否则它将继续返回 REST 响应
解决方案:按照问题中的说明设置重定向,然后等待 S3 和 CloudFront 缓存时间。它们可能需要 4 小时或更长时间,因此您只需将其全部设置好,然后等待并期待最好的结果。
(这是评论中迈克尔的解决方案,但现在已经有好几年了,这真的应该被标记为已回答)。
因为我无法发表评论,所以写作为答案 - 从http://docs.aws.amazon.com/AmazonCloudFront/latest/APIReference/DistributionConfigDatatype.html#DistributionConfigDatatype_Elements的文档看来您可以有一个空白的默认根对象: