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/92507/9250779ce9d0d937cdd9837f7ffd426f72e27cf9" 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/e829e/e829e9b7d10218be572b41ba075499ee0a82a997" alt="iShot_2024-07-16_09 13 55"
Create clound9 for writing lamda function source code
data:image/s3,"s3://crabby-images/ee2e2/ee2e2ef5c1f60767a07e261dca2422e180c0f7c1" alt="image"
Write lamda function
Write code (See this repository source code)
data:image/s3,"s3://crabby-images/cbaa9/cbaa9afbf3e21b34dd5a3200b826ef2354a9a2ae" alt="image"
Upload Lamda
data:image/s3,"s3://crabby-images/cac30/cac3065a57301d9a16d9bf1a21071fc65a1ce557" 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/a37de/a37dec2d2587c9e7b705ed049ca1bef3998ea352" alt="iShot_2024-07-16_09 14 17"
Deploy
data:image/s3,"s3://crabby-images/b6616/b6616676c6ac20a44a8f2a5b496be9c2c338244c" alt="iShot_2024-07-16_09 13 23"