Skip to content

ryanontheinside/comfystream_inside

 
 

Repository files navigation

comfystream

comfystream is a package for running img2img Comfy workflows on video streams.

This repo also includes a WebRTC server and UI that uses comfystream to support streaming from a webcam and processing the stream with a workflow JSON file (API format) created in ComfyUI. If you have an existing ComfyUI installation, the same custom nodes used to create the workflow in ComfyUI will be re-used when processing the video stream.

Quick Start

The fastest way to get started is to follow this tutorial by @ryanontheinside.

For additional information, refer to the remaining sections below.

Install package

Prerequisites

A separate environment can be used to avoid any dependency issues with an existing ComfyUI installation.

Create the environment:

conda create -n comfystream python=3.11

Activate the environment:

conda activate comfystream

Make sure you have PyTorch installed.

Install comfystream:

pip install git+https://github.com/yondonfu/comfystream.git

# This can be used to install from a local repo
# pip install .
# This can be used to install from a local repo in edit mode
# pip install -e .

Custom Nodes

comfystream uses a few custom nodes to support running workflows.

Copy the custom nodes into the custom_nodes folder of your ComfyUI workspace:

cp -r nodes/* custom_nodes/

For example, if your ComfyUI workspace is under /home/user/ComfyUI:

cp -r nodes/* /home/user/ComfyUI/custom_nodes

Usage

See example.py.

Run tests

Install dev dependencies:

pip install .[dev]

Run tests:

pytest

Run server

Install dependencies:

pip install -r requirements.txt

If you have existing custom nodes in your ComfyUI workspace, you will need to install their requirements in your current environment:

python install.py --workspace <COMFY_WORKSPACE>

Run the server:

python server/app.py --workspace <COMFY_WORKSPACE>

Show additional options for configuring the server:

python server/app.py -h

Remote Setup

A local server should connect with a local UI out-of-the-box. It is also possible to run a local UI and connect with a remote server, but there may be additional dependencies.

In order for the remote server to connect with another peer (i.e. a browser) without any additional dependencies you will need to allow inbound/outbound UDP traffic on ports 1024-65535 (source).

If you only have a subset of those UDP ports available, you can use the --media-ports flag to specify a comma delimited list of ports to use:

python server/app.py --workspace <COMFY_WORKSPACE> --media-ports 1024,1025,...

If you are running the server in a restrictive network environment where this is not possible, you will need to use a TURN server.

At the moment, the server supports using Twilio's TURN servers (although it is easy to make the update to support arbitrary TURN servers):

  1. Sign up for a Twilio account.
  2. Copy the Account SID and Auth Token from https://console.twilio.com/.
  3. Set the TWILIO_ACCOUNT_SID and TWILIO_AUTH_TOKEN environment variables.
export TWILIO_ACCOUNT_SID=...
export TWILIO_AUTH_TOKEN=...

Run UI

Prerequisities

Install dependencies

cd ui
npm install --legacy-peer-deps

Run local dev server:

npm run dev

By default the app will be available at http://localhost:3000.

The Stream URL is the URL of the server which defaults to http://127.0.0.1:8888.

Limitations

At the moment, a workflow must fufill the following requirements:

  • The workflow must have a single primary input node that will receive individual video frames
    • The primary input node is designed by one of the following:
      • A single PrimaryInputLoadImage node (see this workflow for example usage)
        • This node can be used as a drop-in replacement for a LoadImage node
        • In this scenario, any number of additional LoadImage nodes can be used
      • A single LoadImage node
        • In this scenario, the workflow can only contain the single LoadImage node
    • At runtime, this node is replaced with a LoadTensor node
  • The workflow must have a single output using a PreviewImage or SaveImage node
    • At runtime, this node is replaced with a SaveTensor node

Troubleshoot

This project has been tested locally successfully with the following setup:

  • OS: Ubuntu
  • GPU: Nvidia RTX 4090
  • Driver: 550.127.05
  • CUDA: 12.5
  • torch: 2.5.1+cu121

About

Run Comfy workflows on video streams

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • TypeScript 68.3%
  • Python 29.7%
  • CSS 1.9%
  • JavaScript 0.1%