This is a simple example of how to use AWS Lambda to resize images on the fly using Amazon CloudFront.
- Low-resolution images on high-resolution displays create a bad user experience.
- High-resolution images on low-resolution displays waste bandwidth, device, and server resources, especially when using a framework that adopts images in-app and crops or resizes images, making the app heavy.
Add query parameters. that's it.
- width
- height
- format ('auto' option check accept request header)
- quality (0~100, default: 100)
- https://your-domain/images/hangang-river.jpeg?width=1100 (940KB)
- https://your-domain/images/hangang-river.jpeg?width=1100&format=webp (658KB)
data:image/s3,"s3://crabby-images/a6548/a65483c6f8869a353434392f7adae71653121a1b" alt="image"
- The user requests an image from CloudFront.
- CloudFront forwards the request to the Lambda function.
- The Lambda function resizes the image and returns it to CloudFront.
- CloudFront caches the image and returns it to the user.
- The next time the same image is requested, CloudFront returns the cached image.
- If the image is updated, the cache is invalidated and the process starts over.
- The Lambda function is only invoked when the image is requested for the first time or when the cache is invalidated.
Create lamda function (choose us-east-1 for using cloudfront response trigger)
data:image/s3,"s3://crabby-images/fd649/fd64953f2721cb65c5b263fd7d5f6a5c37752057" alt="iShot_2024-07-16_09 13 55"
Create clound9 for writing lamda function source code
data:image/s3,"s3://crabby-images/46cfd/46cfd9539617653609ae8d441cec1144b7423a05" alt="image"
Write lamda function
Write code (See this repository source code)
data:image/s3,"s3://crabby-images/b1a82/b1a824bfb3c60993246de1d6f7bda1bd47a7a4ee" alt="image"
Upload Lamda
data:image/s3,"s3://crabby-images/41b00/41b0082395fbc090d272efede3bae01dd4330457" alt="image"
Select "Directory" -> "No" -> Select proejct folder -> Open (just few minutes left, it will show complete message toast)
Add Trigger
data:image/s3,"s3://crabby-images/ee32f/ee32f65c0a641706a8202870e6e91601b5ddcbd1" alt="iShot_2024-07-16_09 14 17"
Deploy
data:image/s3,"s3://crabby-images/62713/62713a8c7f9c5b4ca74f4ed4cf5570d00e1bce86" alt="iShot_2024-07-16_09 13 23"