https://github.com/runpod-workers/worker-comfyui
ComfyUI as a serverless API on RunPod
https://github.com/runpod-workers/worker-comfyui
ai comfyui docker pod runpod sdxl serverless stable-diffusion worker
Last synced: 5 months ago
JSON representation
ComfyUI as a serverless API on RunPod
- Host: GitHub
- URL: https://github.com/runpod-workers/worker-comfyui
- Owner: runpod-workers
- License: agpl-3.0
- Created: 2023-10-09T19:18:26.000Z (about 2 years ago)
- Default Branch: main
- Last Pushed: 2025-05-09T11:40:34.000Z (5 months ago)
- Last Synced: 2025-05-09T12:35:05.774Z (5 months ago)
- Topics: ai, comfyui, docker, pod, runpod, sdxl, serverless, stable-diffusion, worker
- Language: Python
- Homepage:
- Size: 3.15 MB
- Stars: 451
- Watchers: 6
- Forks: 371
- Open Issues: 43
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: .github/CONTRIBUTING.md
- License: LICENSE
- Code of conduct: .github/CODE_OF_CONDUCT.md
- Security: .github/SECURITY.md
Awesome Lists containing this project
README
# worker-comfyui
> [ComfyUI](https://github.com/comfyanonymous/ComfyUI) as a serverless API on [RunPod](https://www.runpod.io/)
![]()
[](https://www.runpod.io/console/hub/runpod-workers/worker-comfyui)
---
This project allows you to run ComfyUI workflows as a serverless API endpoint on the RunPod platform. Submit workflows via API calls and receive generated images as base64 strings or S3 URLs.
## Table of Contents
- [Quickstart](#quickstart)
- [Available Docker Images](#available-docker-images)
- [API Specification](#api-specification)
- [Usage](#usage)
- [Getting the Workflow JSON](#getting-the-workflow-json)
- [Further Documentation](#further-documentation)---
## Quickstart
1. ๐ณ Choose one of the [available Docker images](#available-docker-images) for your serverless endpoint (e.g., `runpod/worker-comfyui:-sd3`).
2. ๐ Follow the [Deployment Guide](docs/deployment.md) to set up your RunPod template and endpoint.
3. โ๏ธ Optionally configure the worker (e.g., for S3 upload) using environment variables - see the full [Configuration Guide](docs/configuration.md).
4. ๐งช Pick an example workflow from [`test_resources/workflows/`](./test_resources/workflows/) or [get your own](#getting-the-workflow-json).
5. ๐ Follow the [Usage](#usage) steps below to interact with your deployed endpoint.## Available Docker Images
These images are available on Docker Hub under `runpod/worker-comfyui`:
- **`runpod/worker-comfyui:-base`**: Clean ComfyUI install with no models.
- **`runpod/worker-comfyui:-flux1-schnell`**: Includes checkpoint, text encoders, and VAE for [FLUX.1 schnell](https://huggingface.co/black-forest-labs/FLUX.1-schnell).
- **`runpod/worker-comfyui:-flux1-dev`**: Includes checkpoint, text encoders, and VAE for [FLUX.1 dev](https://huggingface.co/black-forest-labs/FLUX.1-dev).
- **`runpod/worker-comfyui:-sdxl`**: Includes checkpoint and VAEs for [Stable Diffusion XL](https://huggingface.co/stabilityai/stable-diffusion-xl-base-1.0).
- **`runpod/worker-comfyui:-sd3`**: Includes checkpoint for [Stable Diffusion 3 medium](https://huggingface.co/stabilityai/stable-diffusion-3-medium).Replace `` with the current release tag, check the [releases page](https://github.com/runpod-workers/worker-comfyui/releases) for the latest version.
## API Specification
The worker exposes standard RunPod serverless endpoints (`/run`, `/runsync`, `/health`). By default, images are returned as base64 strings. You can configure the worker to upload images to an S3 bucket instead by setting specific environment variables (see [Configuration Guide](docs/configuration.md)).
Use the `/runsync` endpoint for synchronous requests that wait for the job to complete and return the result directly. Use the `/run` endpoint for asynchronous requests that return immediately with a job ID; you'll need to poll the `/status` endpoint separately to get the result.
### Input
```json
{
"input": {
"workflow": {
"6": {
"inputs": {
"text": "a ball on the table",
"clip": ["30", 1]
},
"class_type": "CLIPTextEncode",
"_meta": {
"title": "CLIP Text Encode (Positive Prompt)"
}
}
},
"images": [
{
"name": "input_image_1.png",
"image": "..."
}
]
}
}
```The following tables describe the fields within the `input` object:
| Field Path | Type | Required | Description |
| ---------------- | ------ | -------- | ------------------------------------------------------------------------------------------------------------------------------------------ |
| `input` | Object | Yes | Top-level object containing request data. |
| `input.workflow` | Object | Yes | The ComfyUI workflow exported in the [required format](#getting-the-workflow-json). |
| `input.images` | Array | No | Optional array of input images. Each image is uploaded to ComfyUI's `input` directory and can be referenced by its `name` in the workflow. |#### `input.images` Object
Each object within the `input.images` array must contain:
| Field Name | Type | Required | Description |
| ---------- | ------ | -------- | --------------------------------------------------------------------------------------------------------------------------------- |
| `name` | String | Yes | Filename used to reference the image in the workflow (e.g., via a "Load Image" node). Must be unique within the array. |
| `image` | String | Yes | Base64 encoded string of the image. A data URI prefix (e.g., `data:image/png;base64,`) is optional and will be handled correctly. |> [!NOTE]
>
> **Size Limits:** RunPod endpoints have request size limits (e.g., 10MB for `/run`, 20MB for `/runsync`). Large base64 input images can exceed these limits. See [RunPod Docs](https://docs.runpod.io/docs/serverless-endpoint-urls).### Output
> [!WARNING]
>
> **Breaking Change in Output Format (5.0.0+)**
>
> Versions `< 5.0.0` returned the primary image data (S3 URL or base64 string) directly within an `output.message` field.
> Starting with `5.0.0`, the output format has changed significantly, see below```json
{
"id": "sync-uuid-string",
"status": "COMPLETED",
"output": {
"images": [
{
"filename": "ComfyUI_00001_.png",
"type": "base64",
"data": "iVBORw0KGgoAAAANSUhEUg..."
}
]
},
"delayTime": 123,
"executionTime": 4567
}
```| Field Path | Type | Required | Description |
| --------------- | ---------------- | -------- | ----------------------------------------------------------------------------------------------------------- |
| `output` | Object | Yes | Top-level object containing the results of the job execution. |
| `output.images` | Array of Objects | No | Present if the workflow generated images. Contains a list of objects, each representing one output image. |
| `output.errors` | Array of Strings | No | Present if non-fatal errors or warnings occurred during processing (e.g., S3 upload failure, missing data). |#### `output.images`
Each object in the `output.images` array has the following structure:
| Field Name | Type | Description |
| ---------- | ------ | ----------------------------------------------------------------------------------------------- |
| `filename` | String | The original filename assigned by ComfyUI during generation. |
| `type` | String | Indicates the format of the data. Either `"base64"` or `"s3_url"` (if S3 upload is configured). |
| `data` | String | Contains either the base64 encoded image string or the S3 URL for the uploaded image file. |> [!NOTE]
> The `output.images` field provides a list of all generated images (excluding temporary ones).
>
> - If S3 upload is **not** configured (default), `type` will be `"base64"` and `data` will contain the base64 encoded image string.
> - If S3 upload **is** configured, `type` will be `"s3_url"` and `data` will contain the S3 URL. See the [Configuration Guide](docs/configuration.md#example-s3-response) for an S3 example response.
> - Clients interacting with the API need to handle this list-based structure under `output.images`.## Usage
To interact with your deployed RunPod endpoint:
1. **Get API Key:** Generate a key in RunPod [User Settings](https://www.runpod.io/console/serverless/user/settings) (`API Keys` section).
2. **Get Endpoint ID:** Find your endpoint ID on the [Serverless Endpoints](https://www.runpod.io/console/serverless/user/endpoints) page or on the `Overview` page of your endpoint.### Generate Image (Sync Example)
Send a workflow to the `/runsync` endpoint (waits for completion). Replace `` and ``. The `-d` value should contain the [JSON input described above](#input).
```bash
curl -X POST \
-H "Authorization: Bearer " \
-H "Content-Type: application/json" \
-d '{"input":{"workflow":{... your workflow JSON ...}}}' \
https://api.runpod.ai/v2//runsync
```You can also use the `/run` endpoint for asynchronous jobs and then poll the `/status` to see when the job is done. Or you [add a `webhook` into your request](https://docs.runpod.io/serverless/endpoints/send-requests#webhook-notifications) to be notified when the job is done.
Refer to [`test_input.json`](./test_input.json) for a complete input example.
## Getting the Workflow JSON
To get the correct `workflow` JSON for the API:
1. Open ComfyUI in your browser.
2. In the top navigation, select `Workflow > Export (API)`
3. A `workflow.json` file will be downloaded. Use the content of this file as the value for the `input.workflow` field in your API requests.## Further Documentation
- **[Deployment Guide](docs/deployment.md):** Detailed steps for deploying on RunPod.
- **[Configuration Guide](docs/configuration.md):** Full list of environment variables (including S3 setup).
- **[Customization Guide](docs/customization.md):** Adding custom models and nodes (Network Volumes, Docker builds).
- **[Development Guide](docs/development.md):** Setting up a local environment for development & testing
- **[CI/CD Guide](docs/ci-cd.md):** Information about the automated Docker build and publish workflows.
- **[Acknowledgments](docs/acknowledgments.md):** Credits and thanks