mirror of
				https://github.com/AbdBarho/stable-diffusion-webui-docker.git
				synced 2025-10-31 02:03:32 -04:00 
			
		
		
		
	Compare commits
	
		
			1 Commits
		
	
	
		
			17f00b9893
			...
			master
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | 802d0bcd68 | 
							
								
								
									
										1
									
								
								.github/workflows/docker.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								.github/workflows/docker.yml
									
									
									
									
										vendored
									
									
								
							| @@ -14,7 +14,6 @@ jobs: | |||||||
|       matrix: |       matrix: | ||||||
|         profile: |         profile: | ||||||
|           - auto |           - auto | ||||||
|           - invoke |  | ||||||
|           - comfy |           - comfy | ||||||
|           - download |           - download | ||||||
|     runs-on: ubuntu-latest |     runs-on: ubuntu-latest | ||||||
|   | |||||||
							
								
								
									
										16
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										16
									
								
								README.md
									
									
									
									
									
								
							| @@ -18,14 +18,6 @@ This repository provides multiple UIs for you to play around with stable diffusi | |||||||
| | ---------------------------------------------------------------------------------------------------------- | ---------------------------------------------------------------------------------------------------------- | ---------------------------------------------------------------------------------------------------------- | | | ---------------------------------------------------------------------------------------------------------- | ---------------------------------------------------------------------------------------------------------- | ---------------------------------------------------------------------------------------------------------- | | ||||||
| |  |  |  | | |  |  |  | | ||||||
|  |  | ||||||
| ### [InvokeAI](https://github.com/invoke-ai/InvokeAI) |  | ||||||
|  |  | ||||||
| [Full feature list here](https://github.com/invoke-ai/InvokeAI#features), Screenshots: |  | ||||||
|  |  | ||||||
| | Text to image                                                                                              | Image to image                                                                                             | Extras                                                                                                     | |  | ||||||
| | ---------------------------------------------------------------------------------------------------------- | ---------------------------------------------------------------------------------------------------------- | ---------------------------------------------------------------------------------------------------------- | |  | ||||||
| |  |  |  | |  | ||||||
|  |  | ||||||
| ### [ComfyUI](https://github.com/comfyanonymous/ComfyUI) | ### [ComfyUI](https://github.com/comfyanonymous/ComfyUI) | ||||||
|  |  | ||||||
| [Full feature list here](https://github.com/comfyanonymous/ComfyUI#features), Screenshot: | [Full feature list here](https://github.com/comfyanonymous/ComfyUI#features), Screenshot: | ||||||
| @@ -34,14 +26,6 @@ This repository provides multiple UIs for you to play around with stable diffusi | |||||||
| | -------------------------------------------------------------------------------- | | | -------------------------------------------------------------------------------- | | ||||||
| |  | | |  | | ||||||
|  |  | ||||||
| ### [Fooocus](https://github.com/comfyanonymous/ComfyUI) |  | ||||||
|  |  | ||||||
| [Full feature list here](https://github.com/lllyasviel/Fooocus#fooocus), Screenshot: |  | ||||||
|  |  | ||||||
| | Simplified UI                                                                    | |  | ||||||
| | -------------------------------------------------------------------------------- | |  | ||||||
| |  | |  | ||||||
|  |  | ||||||
| ## Contributing | ## Contributing | ||||||
|  |  | ||||||
| Contributions are welcome! **Create a discussion first of what the problem is and what you want to contribute (before you implement anything)** | Contributions are welcome! **Create a discussion first of what the problem is and what you want to contribute (before you implement anything)** | ||||||
|   | |||||||
| @@ -38,22 +38,6 @@ services: | |||||||
|     environment: |     environment: | ||||||
|       - CLI_ARGS=--no-half --precision full --allow-code --enable-insecure-extension-access --api |       - CLI_ARGS=--no-half --precision full --allow-code --enable-insecure-extension-access --api | ||||||
|  |  | ||||||
|   invoke: &invoke |  | ||||||
|     <<: *base_service |  | ||||||
|     profiles: ["invoke"] |  | ||||||
|     build: ./services/invoke/ |  | ||||||
|     image: sd-invoke:31 |  | ||||||
|     environment: |  | ||||||
|       - PRELOAD=true |  | ||||||
|       - CLI_ARGS=--xformers |  | ||||||
|  |  | ||||||
|   # invoke-cpu: |  | ||||||
|   #   <<: *invoke |  | ||||||
|   #   profiles: ["invoke-cpu"] |  | ||||||
|   #   environment: |  | ||||||
|   #     - PRELOAD=true |  | ||||||
|   #     - CLI_ARGS=--always_use_cpu |  | ||||||
|  |  | ||||||
|   comfy: &comfy |   comfy: &comfy | ||||||
|     <<: *base_service |     <<: *base_service | ||||||
|     profiles: ["comfy"] |     profiles: ["comfy"] | ||||||
| @@ -69,11 +53,3 @@ services: | |||||||
|     deploy: {} |     deploy: {} | ||||||
|     environment: |     environment: | ||||||
|       - CLI_ARGS=--cpu |       - CLI_ARGS=--cpu | ||||||
|  |  | ||||||
|   fooocus: &fooocus |  | ||||||
|     <<: *base_service |  | ||||||
|     profiles: ["fooocus"] |  | ||||||
|     build: ./services/fooocus/ |  | ||||||
|     image: sd-fooocus:3 |  | ||||||
|     environment: |  | ||||||
|       - CLI_ARGS= |  | ||||||
| @@ -1,47 +0,0 @@ | |||||||
| FROM alpine:3.17 as xformers |  | ||||||
| RUN apk add --no-cache aria2 |  | ||||||
| RUN aria2c -x 5 --dir / --out wheel.whl 'https://github.com/AbdBarho/stable-diffusion-webui-docker/releases/download/6.0.0/xformers-0.0.21.dev544-cp310-cp310-manylinux2014_x86_64-pytorch201.whl' |  | ||||||
|  |  | ||||||
| FROM pytorch/pytorch:2.0.1-cuda11.7-cudnn8-runtime |  | ||||||
|  |  | ||||||
| ENV DEBIAN_FRONTEND=noninteractive PIP_PREFER_BINARY=1 |  | ||||||
|  |  | ||||||
| RUN apt-get update && apt-get install -y git && apt-get clean |  | ||||||
|  |  | ||||||
| # add in required packages |  | ||||||
| RUN apt-get install 'libglib2.0-0'  -y |  | ||||||
| RUN apt-get install 'libgl1-mesa-glx' -y |  | ||||||
| RUN apt-get install 'python-dev' -y |  | ||||||
|  |  | ||||||
| # set this to your target branch commit |  | ||||||
| ARG BRANCH=main SHA=e2f9bcb11d06216d6800676c48d8d74d6fd77a4b |  | ||||||
|  |  | ||||||
| ENV ROOT=/stable-diffusion |  | ||||||
| RUN --mount=type=cache,target=/root/.cache/pip \ |  | ||||||
|   git clone https://github.com/lllyasviel/Fooocus.git ${ROOT} && \ |  | ||||||
|   cd ${ROOT} && \ |  | ||||||
|   git checkout ${BRANCH} && \ |  | ||||||
|   git reset --hard ${SHA} && \ |  | ||||||
|   pip install -r requirements_versions.txt |  | ||||||
|  |  | ||||||
|  |  | ||||||
| RUN --mount=type=cache,target=/root/.cache/pip  \ |  | ||||||
|   --mount=type=bind,from=xformers,source=/wheel.whl,target=/xformers-0.0.21-cp310-cp310-linux_x86_64.whl \ |  | ||||||
|   pip install /xformers-0.0.21-cp310-cp310-linux_x86_64.whl |  | ||||||
|  |  | ||||||
| WORKDIR ${ROOT} |  | ||||||
|  |  | ||||||
| RUN --mount=type=cache,target=/root/.cache/pip \ |  | ||||||
|   git fetch && \ |  | ||||||
|   git checkout ${BRANCH} && \ |  | ||||||
|   git reset --hard ${SHA} && \ |  | ||||||
|   pip install -r requirements_versions.txt |  | ||||||
|  |  | ||||||
| # add info |  | ||||||
| COPY . /docker/ |  | ||||||
| RUN cp /docker/config.txt ${ROOT} |  | ||||||
| RUN chmod u+x /docker/entrypoint.sh |  | ||||||
|  |  | ||||||
| EXPOSE 7860 |  | ||||||
| ENTRYPOINT ["/docker/entrypoint.sh"] |  | ||||||
| CMD python -u entry_with_update.py --listen --port 7860 ${CLI_ARGS} |  | ||||||
| @@ -1,12 +0,0 @@ | |||||||
| { |  | ||||||
|     "path_checkpoints": "/stable-diffusion/models/checkpoints", |  | ||||||
|     "path_loras": "/stable-diffusion/models/loras", |  | ||||||
|     "path_embeddings": "/stable-diffusion/models/embeddings", |  | ||||||
|     "path_vae_approx": "/stable-diffusion/models/vae_approx", |  | ||||||
|     "path_upscale_models": "/stable-diffusion/models/upscale_models", |  | ||||||
|     "path_inpaint": "/stable-diffusion/models/inpaint", |  | ||||||
|     "path_controlnet": "/stable-diffusion/models/controlnet", |  | ||||||
|     "path_clip_vision": "/stable-diffusion/models/clip_vision", |  | ||||||
|     "path_fooocus_expansion": "/stable-diffusion/models/prompt_expansion/fooocus_expansion", |  | ||||||
|     "path_outputs": "/stable-diffusion/outputs" |  | ||||||
| } |  | ||||||
| @@ -1,33 +0,0 @@ | |||||||
| #!/bin/bash |  | ||||||
|  |  | ||||||
| set -Eeuo pipefail |  | ||||||
|  |  | ||||||
| mkdir -vp /data/config/fooocus/wildcards |  | ||||||
|  |  | ||||||
| declare -A MOUNTS |  | ||||||
|  |  | ||||||
| MOUNTS["${ROOT}/outputs"]="/output/fooocus" |  | ||||||
|  |  | ||||||
| # ui specific mounts |  | ||||||
| MOUNTS["${ROOT}/models/checkpoints"]=/data/models/Stable-diffusion/ |  | ||||||
| MOUNTS["${ROOT}/models/loras"]=/data/models/Lora/ |  | ||||||
| MOUNTS["${ROOT}/models/embeddings"]=/data/models/embeddings/ |  | ||||||
| MOUNTS["${ROOT}/models/vae_approx"]=/data/models/VAE/ |  | ||||||
| MOUNTS["${ROOT}/models/upscale_models"]=/data/models/upscale_models/ |  | ||||||
| MOUNTS["${ROOT}/wildcards"]=/data/config/fooocus/wildcards |  | ||||||
|  |  | ||||||
| for to_path in "${!MOUNTS[@]}"; do |  | ||||||
|   set -Eeuo pipefail |  | ||||||
|   from_path="${MOUNTS[${to_path}]}" |  | ||||||
|   rm -rf "${to_path}" |  | ||||||
|   mkdir -p "$(dirname "${to_path}")" |  | ||||||
|   # ends with slash, make it! |  | ||||||
|   if [[ "$from_path" == */ ]]; then |  | ||||||
|     mkdir -vp "$from_path" |  | ||||||
|   fi |  | ||||||
|  |  | ||||||
|   ln -sT "${from_path}" "${to_path}" |  | ||||||
|   echo Mounted $(basename "${from_path}") |  | ||||||
| done |  | ||||||
|  |  | ||||||
| exec "$@" |  | ||||||
| @@ -1,53 +0,0 @@ | |||||||
| FROM alpine:3.17 as xformers |  | ||||||
| RUN apk add --no-cache aria2 |  | ||||||
| RUN aria2c -x 5 --dir / --out wheel.whl 'https://github.com/AbdBarho/stable-diffusion-webui-docker/releases/download/6.0.0/xformers-0.0.21.dev544-cp310-cp310-manylinux2014_x86_64-pytorch201.whl' |  | ||||||
|  |  | ||||||
|  |  | ||||||
| FROM pytorch/pytorch:2.3.0-cuda12.1-cudnn8-runtime |  | ||||||
|  |  | ||||||
| ENV DEBIAN_FRONTEND=noninteractive PIP_EXISTS_ACTION=w PIP_PREFER_BINARY=1 |  | ||||||
|  |  | ||||||
| # patch match: |  | ||||||
| # https://github.com/invoke-ai/InvokeAI/blob/main/docs/installation/INSTALL_PATCHMATCH.md |  | ||||||
| RUN --mount=type=cache,target=/var/cache/apt \ |  | ||||||
|   apt-get update && \ |  | ||||||
|   apt-get install make g++ git libopencv-dev -y && \ |  | ||||||
|   apt-get clean && \ |  | ||||||
|   cd /usr/lib/x86_64-linux-gnu/pkgconfig/ && \ |  | ||||||
|   ln -sf opencv4.pc opencv.pc |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ENV ROOT=/InvokeAI |  | ||||||
| RUN git clone https://github.com/invoke-ai/InvokeAI.git ${ROOT} |  | ||||||
| WORKDIR ${ROOT} |  | ||||||
|  |  | ||||||
| RUN --mount=type=cache,target=/root/.cache/pip \ |  | ||||||
|   git reset --hard f3b2e02921927d9317255b1c3811f47bd40a2bf9 && \ |  | ||||||
|   pip install -e . |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ARG BRANCH=main SHA=f3b2e02921927d9317255b1c3811f47bd40a2bf9 |  | ||||||
| RUN --mount=type=cache,target=/root/.cache/pip \ |  | ||||||
|   git fetch && \ |  | ||||||
|   git reset --hard && \ |  | ||||||
|   git checkout ${BRANCH} && \ |  | ||||||
|   git reset --hard ${SHA} && \ |  | ||||||
|   pip install -U -e . |  | ||||||
|  |  | ||||||
| RUN --mount=type=cache,target=/root/.cache/pip \ |  | ||||||
|   --mount=type=bind,from=xformers,source=/wheel.whl,target=/xformers-0.0.21-cp310-cp310-linux_x86_64.whl \ |  | ||||||
|   pip install -U opencv-python-headless triton /xformers-0.0.21-cp310-cp310-linux_x86_64.whl && \ |  | ||||||
|   python3 -c "from patchmatch import patch_match" |  | ||||||
|  |  | ||||||
|  |  | ||||||
| COPY . /docker/ |  | ||||||
|  |  | ||||||
| ENV NVIDIA_VISIBLE_DEVICES=all |  | ||||||
| ENV PYTHONUNBUFFERED=1 PRELOAD=false HF_HOME=/root/.cache/huggingface CONFIG_DIR=/data/config/invoke CLI_ARGS="" |  | ||||||
| EXPOSE 7860 |  | ||||||
|  |  | ||||||
| ENTRYPOINT ["/docker/entrypoint.sh"] |  | ||||||
| CMD invokeai --web --host 0.0.0.0 --port 7860 --root_dir ${ROOT} --config ${CONFIG_DIR}/models.yaml \ |  | ||||||
|   --outdir /output/invoke --embedding_directory /data/embeddings/ --lora_directory /data/models/Lora \ |  | ||||||
|   --no-nsfw_checker --no-safety_checker ${CLI_ARGS} |  | ||||||
|  |  | ||||||
| @@ -1,45 +0,0 @@ | |||||||
| #!/bin/bash |  | ||||||
|  |  | ||||||
| set -Eeuo pipefail |  | ||||||
|  |  | ||||||
| declare -A MOUNTS |  | ||||||
|  |  | ||||||
| mkdir -p ${CONFIG_DIR} ${ROOT}/configs/stable-diffusion/ |  | ||||||
|  |  | ||||||
| # cache |  | ||||||
| MOUNTS["/root/.cache"]=/data/.cache/ |  | ||||||
|  |  | ||||||
| # this is really just a hack to avoid migrations |  | ||||||
| rm -rf ${HF_HOME}/diffusers |  | ||||||
|  |  | ||||||
| # ui specific |  | ||||||
| MOUNTS["${ROOT}/models/codeformer"]=/data/models/Codeformer/ |  | ||||||
| MOUNTS["${ROOT}/models/gfpgan/GFPGANv1.4.pth"]=/data/models/GFPGAN/GFPGANv1.4.pth |  | ||||||
| MOUNTS["${ROOT}/models/gfpgan/weights"]=/data/models/GFPGAN/ |  | ||||||
| MOUNTS["${ROOT}/models/realesrgan"]=/data/models/RealESRGAN/ |  | ||||||
|  |  | ||||||
| MOUNTS["${ROOT}/models/ldm"]=/data/.cache/invoke/ldm/ |  | ||||||
|  |  | ||||||
| # hacks |  | ||||||
|  |  | ||||||
| for to_path in "${!MOUNTS[@]}"; do |  | ||||||
|   set -Eeuo pipefail |  | ||||||
|   from_path="${MOUNTS[${to_path}]}" |  | ||||||
|   rm -rf "${to_path}" |  | ||||||
|   mkdir -p "$(dirname "${to_path}")" |  | ||||||
|   # ends with slash, make it! |  | ||||||
|   if [[ "$from_path" == */ ]]; then |  | ||||||
|     mkdir -vp "$from_path" |  | ||||||
|   fi |  | ||||||
|  |  | ||||||
|   ln -sT "${from_path}" "${to_path}" |  | ||||||
|   echo Mounted $(basename "${from_path}") |  | ||||||
| done |  | ||||||
|  |  | ||||||
| if "${PRELOAD}" == "true"; then |  | ||||||
|   set -Eeuo pipefail |  | ||||||
|   invokeai-configure --root ${ROOT} --yes |  | ||||||
|   cp ${ROOT}/configs/models.yaml ${CONFIG_DIR}/models.yaml |  | ||||||
| fi |  | ||||||
|  |  | ||||||
| exec "$@" |  | ||||||
		Reference in New Issue
	
	Block a user