Image Processing
Since parallel steps are not yet available in workflow-py, Python example is implemented in a sequential manner. See our Roadmap for feature parity plans and Changelog for updates.
Introduction
This example demonstrates how to process images using Upstash Workflow. The following workflow will upload an image, resize it into multiple resolutions, apply filters, and store the processed versions for later retrieval.
Use Case
Our workflow will:
- Receive an image upload request
- Resize the image into different resolutions
- Apply various filters to the resized images
- Store the processed images in a cloud storage
Code Example
Code Breakdown
1. Retrieving the Image
We begin by getting the URL of the uploaded image based on its ID:
2. Resizing the Image
We resize the image into three different resolutions (640, 1280, 1920) using an external image processing service.
We call context.call
for each resolution and use Promise.all
to run them parallel:
3. Applying Filters
After resizing, we apply filters such as grayscale, sepia, and contrast to the resized images.
Again, we call context.call
for each filter & image pair. We collect the promises of these requests in an array processedImagePromise
. Then, we call Promise.all
again to run them all parallel.
4. Storing the Processed Images
We store each processed image in cloud storage and return the URLs of the stored images:
Key Features
- Batch Processing: This workflow handles batch resizing and filtering of images in parallel to minimize processing time.
- Scalability: Image resizing and filtering are handled through external services, making it easy to scale. Also, the requests to these services are handled by QStash, not by the compute where the workflow is hosted.
- Storage Integration: The workflow integrates with cloud storage to persist processed images for future access.
Was this page helpful?