我有一個應用程序,它提供一個動態的html和一些用NodeJS/Express編寫的靜態文件。在NodeJS Express前部署CloudFront
我部署的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
,並且express從mydomain.com/
提供靜態文件。
是否有人在NodeJS/Express之前成功部署了CloudFront以獲取靜態文件?我真的不明白是什麼問題。
謝謝!
我嘗試添加兩個來源'mydomain/path/app_id'和'mydomain',但它沒有任何區別 –
查看您的服務器日誌以查看實際請求的內容。另外,在測試時將您的[錯誤緩存最小TTL](https://stackoverflow.com/a/35541525/1695906)設置爲0。否則默認情況下,CloudFront緩存錯誤響應5分鐘。如上所述,「年齡:116」幾乎是2分鐘的時間,如果你現在和之後解決了問題,你就不會看到它,並且不會有原始服務器日誌條目。 –