ImageKit.io provides two ways to deliver images for your website - from the media library, or your server/storage. Each of these image sources follow certain caching rules pre-determined by ImageKit.io. Additionally, you can define your own caching rules, if needed.
- The original copies of the images and files are stored permanently within the Media library when using the Media Library to store and deliver the images.
- When using your server or storage as an origin to deliver images, the original copies of the images and files stay within your servers, and ImageKit.io does not control how long the files remain there. Imagekit.io will access the original file from your origin and performs all the optimizations on this file. If you have the setting for "Save a copy of original images" switched on for your Enterprise account, ImageKit maintains a copy of your original image as well within its internal caches and performs all the optimizations on this copy of the original instead of going to your origin to access the image.
- The transformed and optimized copies of the images and files, when requested via a URL, are stored in line with the cache headers. This not only improves the performance for repeat requests, but ensures the number of requests made to your origin server or storage is less. However, ImageKit.io might change this practice for a specific account or all accounts, if and when necessary.
- Every image URL is cached at the CDN, and other ImageKit.io internal caches, for a maximum of 180 days. This is done to ensure fast delivery of images across the globe.
{% hint style="info" %} Files that are explicitly uploaded to the media library are charged as per your pricing plan. You are not billed for the storage consumed by the transformed and optimized copies of the files. The "Save a copy of original images" feature is separately chargeable on Enterprise plans. You can discuss this with your Customer Success Manager or Account Executive. {% endhint %}
Cache-control time can be modified for the files that are being delivered from your storage or server attached to ImageKit.io, but not for the files stored within the Media library.
This option allows caching based on the cache control headers being passed from your origin attached to ImageKit.io. For example, if your origin (server or storage) sends a cache-control header to cache a file for 1 hour, ImageKit.io applies the cache-control header across all its internal caches, generated transformations, and CDN. This ensures that the cache control set by you is obeyed at all times.
This feature can be applied for any URL endpoint in your ImageKit account.
Note: Origin-Based Cache Control is disabled by default. Reach out to ImageKit's support team to enable it for your account.
ImageKit.io caches a copy of every transformed and optimized image at the CDN. Additionally, ImageKit.io also maintains its internal caches, which are co-located with its processing engine across 6 global locations. In case any URL is missed by the CDN, internal caches deliver the resources without passing on the request to your server or storage. The same process is followed when you integrate ImageKit.io with a custom CDN.