-
Notifications
You must be signed in to change notification settings - Fork 541
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
How to setup cache TTL for the processed images #107
Comments
Hey @biosini: here's some references for your questions. The response headers piece looks to be a joint issue between CloudFront and S3, so we will look into the integrations on our end to see if there's anything we can do. |
Hi @hayesry! So basically in the CloudFormation template I could add the following:
I'm a bit confused about the Many thanks, |
@biosini Based on the documentation, I think you can get away with just specifying the DefaultTTL value. The differences MaximumTTL and MinimumTTL aren't made super clear and might step on each other's toes if they're both specified. That's just based on my experience though. Here's what I was reading into: (https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-cloudfront-distribution-defaultcachebehavior.html#cfn-cloudfront-distribution-defaultcachebehavior-minttl) For client-side caching, it appears that this is an ongoing feature request for CloudFront. However, they don't provide ETA's for when features will be implemented. I'll take a look on our end and see if there's anything that can be done to the code to help facilitate this or provide a workaround! |
Sounds good! I'll wait for that. Thanks |
Hey @biosini: Not sure if you've found a workaround/solution in the meantime, but I've added the Cache-Control header issue as a feature request to be looked into in a future release of the solution. My guess is that this is something that could be added directly in the Lambda response, so we'll research this a bit more and hopefully have a code-based fix! |
Hi @hayesry! No, I didn't found any solution for the missing Cache-Control header.
What do you think? |
This is an issue for us too. As everytime a request would be sent to cloudfront driving up the bills. |
This is a real issue, not just for the bills, but also for the loading times of webpages that include the same images. Can confirm that the original S3 header seems to be ignored. |
We downloaded the source, made the change and redeployed. Now Expires is working for us ( I guess unless they fix it, doing it ourselves was our only option ). |
@shsenior, what do you think about ideas proposed above? It would be cool to pass headers just like before 4.0 👍 |
@mandys would you be able to share the code you used? I modified the index.js to include a Cache-Control, but it appears it is still being served from Cloudfront when testing. Here is the change I made - |
@mandys, please ignore, the above code change does appear to have worked and the Cache-Control exists and is honored. I was refreshing the same page in chrome which I guess does not honor the cache. Opening the same url in another tab did hit the cache, so it appears that the change above is caching properly. |
@NewToScripting where can I update my code in AWS or do i need to rebuild it somehow and upload the new template? |
Just wanted to add my vote for this feature. It would also be great if we can set it at the setup level like CORS, demo site, etc |
+1 |
We have updated our solution, and I believe your issue has been fixed. If you still see the issue with the latest version (v4.2), please feel free to reopen the issue. You can refer to the recent changes here |
I noticed a too short caching TTL for the processed images on CloudFront.
How I can change the TTL?
Also, I noticed that CloudFront is not responding with a Cache-Control header.
How I can set it up?
Thanks,
Fabio
The text was updated successfully, but these errors were encountered: