我有一个应用程序,它提供动态html和一些用NodeJS / Express编写的静态文件。
我在它前面部署了一个AWS CloudFront发行版,但只有HTML通过,所有静态文件都会生成404.请求的标题如下所示:
Age:116
Connection:keep-alive
Content-Length:170
Content-Security-Policy:default-src 'self'
Content-Type:text/html; charset=utf-8
Date:Mon, 09 Oct 2017 14:37:23 GMT
Server:nginx/1.6.2
Via:1.1 523db8f46d98334ac6b5debbf315e15b.cloudfront.net (CloudFront), 1.1 proxy1.xxx.yy (squid/4.0.17)
X-Amz-Cf-Id:5UYpluGn8TxUxsxmmDYYiZnjbOWbZ7iFFit55mmgcN6IbAJHCEAX6Q==
X-Cache:MISS from proxy1.xxx.yy
X-Cache:Error from cloudfront
X-Cache-Lookup:MISS from proxy1.xxx.yy:3128
X-Content-Type-Options:nosniff
X-Powered-By:Express
有关信息,我的nodejs应用程序在某个端口运行,nginx将其反向代理到我使用proxy_pass
指定的域。
你可以看到我在另一个代理后面,但这不是问题所在。
我认为发生的事情是我的来源看起来像mydomain.com/path/app_id
并且表达来自mydomain.com/
的静态文件。
是否有人在NodeJS / Express前面为静态文件成功部署了CloudFront?我真的不明白这个问题是什么..
谢谢!
答案 0 :(得分:0)
要从另一条路径提供文件,流程如下:
mydomain.com/path/app_id
和mydomain.com
(不会尾随/
))/img
)。因此,我们可以为img/*
,js/*
和css/*
添加行为。然后可以将每个行为设置为单个原点。在这种情况下,我们选择之前名为mydomain.com
的{{1}}。