Created
June 8, 2017 13:38
-
-
Save kellyrmilligan/e242d3dc743105fe91a83cc933ee1314 to your computer and use it in GitHub Desktop.
Sync files to s3 and set cache control headers
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
#!/bin/bash | |
if [[ "$1" != "" ]]; then | |
S3BUCKETNAME="$1" | |
else | |
echo ERROR: Failed to supply S3 bucket name | |
exit 1 | |
fi | |
aws s3 sync build s3://$S3BUCKETNAME --delete --cache-control max-age=31536000,public | |
aws s3 cp s3://$S3BUCKETNAME/service-worker.js s3://$S3BUCKETNAME/service-worker.js --metadata-directive REPLACE --cache-control max-age=0,no-cache,no-store,must-revalidate --content-type application/javascript --acl public-read | |
aws s3 cp s3://$S3BUCKETNAME/index.html s3://$S3BUCKETNAME/index.html --metadata-directive REPLACE --cache-control max-age=0,no-cache,no-store,must-revalidate --content-type text/html --acl public-read |
This was the top Google result for aws s3 cp respect cache-control
, and was exactly what I was looking for. Thanks @kellyrmilligan !
Nice!
The cache-control
directive doesn't make sense here:
max-age=0,no-cache,no-store,must-revalidate
no-cache
andno-store
have different effects and are mutually exclusive, meaning the browser cannot adhere to both at the same timeno-cache
already equalsmust-revalidate
.no-store
already equalsmax-age=0
.
I use no-cache
for my html
files to ensure that I never serve stale versions while minimizing my bandwidth costs.
Here's a great resource for figuring this out for yourself: https://web.dev/http-cache/#defining-optimal-cache-control-policy
thanks !
no-store
already equalsmax-age=0
.
no-store
is not equal to max-age=0
https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Cache-Control#preventing_caching
Thanks for the commands example, however, the Cache-Control
directive in it is plainly wrong and doesn't make sense, as also mentioned by the @agconti.
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Based on the suggestions above, I created this script: https://gist.github.com/kevindice/87ee5ffca9523810253de3d9a41c3ae5
Usage:
./react-app-s3-sync.sh $S3_BUCKET_NAME $CLOUDFRONT_DISTRIBUTION_ID