Skip to main content

Stable Diffusion server built with FastAPI

Project description

Stable Diffusion Google Colab FastAPI Server

Note: This is a pretty hacky server / client interface for generic Stable Diffusion pipelines using diffusers. It's not made for production use and hasn't really been optimized completely.

Installation

From pip:

pip install sd-server

From source:

git clone git@github.com:shyamsn97/stable-diffusion-server.git
cd stable-diffusion-server/
python setup.py install

Stable Diffusion Server + Client Interface -- Simple Usage

Here we create a simple server hosting the standard StableDiffusionPipeline. The client takes in **kwargs that should be the arguments passed into the __call__ function from the pipeline. For instance, the StableDiffusionPipeline __call__ method can be found: https://github.com/huggingface/diffusers/blob/main/src/diffusers/pipelines/stable_diffusion/pipeline_stable_diffusion.py#L185. host and port can be specified in the start method for generic hosting.

from sd_server import DiffusersServer, DiffusersClient
from diffusers import StableDiffusionPipeline

STABLE_DIFFUSION_PATH = "runwayml/stable-diffusion-v1-5" # this can be a local path
pipeline_kwargs = {
    "revision":"fp16",
    "torch_dtype":torch.float16
}
device = torch.device('cuda')

server = DiffusersServer.create(
    pretrained_path = STABLE_DIFFUSION_PATH,
    pipeline_cls = StableDiffusionPipeline,
    pipeline_kwargs = pipeline_kwargs,
    enable_attention_slicing = True,
    device = device
)
url = server.start(host="127.0.0.1", port=8000) # url -- either remote or local

# on another host / terminal
client = DiffusersClient(url)

responses = client(prompt='a photo of an astronaut riding a horse on mars', num_images_per_prompt=4) # this should return a list of images

Serving from Google Colab

Using the server in Google Colab requires an ngrok account, and needs your ngrok auth token https://dashboard.ngrok.com/get-started/your-authtoken to be passed to the server. Note: Ngrok basically opens a tunnel from a dev machine to the cloud, which means its not really that secure, and should be used at your own risk. Read more here: https://stackoverflow.com/questions/36552950/is-ngrok-safe-to-use-or-can-it-be-compromised

NGROK_AUTH_KEY = "your auth key from https://dashboard.ngrok.com/get-started/your-authtoken"

... # imports from above

server = DiffusersServer.create(
    pretrained_path = STABLE_DIFFUSION_PATH,
    pipeline_cls = StableDiffusionPipeline,
    pipeline_kwargs = pipeline_kwargs,
    enable_attention_slicing = True,
    device = device
)

url = server.start(ngrok_auth_token=NGROK_AUTH_KEY)

# on another host
client = DiffusersClient(url)

responses = client(prompt='a photo of an astronaut riding a horse on mars', num_images_per_prompt=4) # this should return a list of images

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

sd-server-0.1.0.tar.gz (5.3 kB view details)

Uploaded Source

Built Distributions

sd_server-0.1.0-py3.9.egg (9.0 kB view details)

Uploaded Source

sd_server-0.1.0-py3-none-any.whl (5.9 kB view details)

Uploaded Python 3

File details

Details for the file sd-server-0.1.0.tar.gz.

File metadata

  • Download URL: sd-server-0.1.0.tar.gz
  • Upload date:
  • Size: 5.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.9.15

File hashes

Hashes for sd-server-0.1.0.tar.gz
Algorithm Hash digest
SHA256 d6a62d204249268f1b123a8a3b9b14bc90e67d92afe6ba1e5c180d21beb4b48a
MD5 c99fc4e4a1de0a1d6c765208016301cc
BLAKE2b-256 b4961ecf459dfc020301594a916f36c2aa486a8a655018734b51ea94f0cf478b

See more details on using hashes here.

File details

Details for the file sd_server-0.1.0-py3.9.egg.

File metadata

  • Download URL: sd_server-0.1.0-py3.9.egg
  • Upload date:
  • Size: 9.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.9.15

File hashes

Hashes for sd_server-0.1.0-py3.9.egg
Algorithm Hash digest
SHA256 3de39ee01a7e04863485488b3d865e9a458c88f4e17bfefea4e1139dc92df8c5
MD5 d6e7f0feaf6dbd4d9677c403756619ed
BLAKE2b-256 7f5b377339ff5ceafd40b77bc699bf3b3dc285c7fb6c455edd0b753e99ccbb96

See more details on using hashes here.

File details

Details for the file sd_server-0.1.0-py3-none-any.whl.

File metadata

  • Download URL: sd_server-0.1.0-py3-none-any.whl
  • Upload date:
  • Size: 5.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.9.15

File hashes

Hashes for sd_server-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 fdc8780177c2292a6660a592656d386cde19ad112510e05a29c5a02f5806c707
MD5 3ea2510179b1543b5d2dac5aa9a0d751
BLAKE2b-256 26109def98289c355a69fa8d7a4ceac153df60b1290886776136d4e6ebef06d6

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page