mirror of
				https://github.com/AbdBarho/stable-diffusion-webui-docker.git
				synced 2025-10-30 17:53:23 -04:00 
			
		
		
		
	Compare commits
	
		
			11 Commits
		
	
	
		
			master
			...
			3e6fa2bb89
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | 3e6fa2bb89 | ||
|  | 5a8e6dccd9 | ||
|  | cfc373d1d1 | ||
|  | 6168e386b4 | ||
|  | 89e258d20d | ||
|  | 4f0e684247 | ||
|  | ff6e3d6fa8 | ||
|  | 056154766c | ||
|  | 74813d56e7 | ||
|  | 77cfe4965e | ||
|  | 18fb90ea22 | 
							
								
								
									
										1
									
								
								.github/workflows/docker.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								.github/workflows/docker.yml
									
									
									
									
										vendored
									
									
								
							| @@ -14,6 +14,7 @@ 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,6 +18,14 @@ 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: | ||||||
| @@ -26,6 +34,14 @@ 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)** | ||||||
|   | |||||||
| @@ -27,7 +27,7 @@ services: | |||||||
|     <<: *base_service |     <<: *base_service | ||||||
|     profiles: ["auto"] |     profiles: ["auto"] | ||||||
|     build: ./services/AUTOMATIC1111 |     build: ./services/AUTOMATIC1111 | ||||||
|     image: sd-auto:78 |     image: sd-auto:77 | ||||||
|     environment: |     environment: | ||||||
|       - CLI_ARGS=--allow-code --medvram --xformers --enable-insecure-extension-access --api |       - CLI_ARGS=--allow-code --medvram --xformers --enable-insecure-extension-access --api | ||||||
|  |  | ||||||
| @@ -38,6 +38,22 @@ 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"] | ||||||
| @@ -53,3 +69,11 @@ 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= | ||||||
| @@ -30,7 +30,7 @@ WORKDIR / | |||||||
| RUN --mount=type=cache,target=/root/.cache/pip \ | RUN --mount=type=cache,target=/root/.cache/pip \ | ||||||
|   git clone https://github.com/AUTOMATIC1111/stable-diffusion-webui.git && \ |   git clone https://github.com/AUTOMATIC1111/stable-diffusion-webui.git && \ | ||||||
|   cd stable-diffusion-webui && \ |   cd stable-diffusion-webui && \ | ||||||
|   git reset --hard v1.9.4 && \ |   git reset --hard v1.9.3 && \ | ||||||
|   pip install -r requirements_versions.txt |   pip install -r requirements_versions.txt | ||||||
|  |  | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										47
									
								
								services/fooocus/Dockerfile
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										47
									
								
								services/fooocus/Dockerfile
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,47 @@ | |||||||
|  | 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} | ||||||
							
								
								
									
										12
									
								
								services/fooocus/config.txt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										12
									
								
								services/fooocus/config.txt
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,12 @@ | |||||||
|  | { | ||||||
|  |     "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" | ||||||
|  | } | ||||||
							
								
								
									
										33
									
								
								services/fooocus/entrypoint.sh
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										33
									
								
								services/fooocus/entrypoint.sh
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,33 @@ | |||||||
|  | #!/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 "$@" | ||||||
							
								
								
									
										53
									
								
								services/invoke/Dockerfile
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										53
									
								
								services/invoke/Dockerfile
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,53 @@ | |||||||
|  | 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} | ||||||
|  |  | ||||||
							
								
								
									
										45
									
								
								services/invoke/entrypoint.sh
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										45
									
								
								services/invoke/entrypoint.sh
									
									
									
									
									
										Executable file
									
								
							| @@ -0,0 +1,45 @@ | |||||||
|  | #!/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