mirror of
				https://github.com/AbdBarho/stable-diffusion-webui-docker.git
				synced 2025-10-31 10:13:28 -04:00 
			
		
		
		
	Compare commits
	
		
			2 Commits
		
	
	
		
			3e6fa2bb89
			...
			9.0.0
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | 802d0bcd68 | ||
|  | b1a26b8041 | 
							
								
								
									
										1
									
								
								.github/workflows/docker.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								.github/workflows/docker.yml
									
									
									
									
										vendored
									
									
								
							| @@ -14,7 +14,6 @@ jobs: | ||||
|       matrix: | ||||
|         profile: | ||||
|           - auto | ||||
|           - invoke | ||||
|           - comfy | ||||
|           - download | ||||
|     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) | ||||
|  | ||||
| [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 | ||||
|  | ||||
| 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 | ||||
|     profiles: ["auto"] | ||||
|     build: ./services/AUTOMATIC1111 | ||||
|     image: sd-auto:77 | ||||
|     image: sd-auto:78 | ||||
|     environment: | ||||
|       - CLI_ARGS=--allow-code --medvram --xformers --enable-insecure-extension-access --api | ||||
|  | ||||
| @@ -38,22 +38,6 @@ services: | ||||
|     environment: | ||||
|       - 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 | ||||
|     <<: *base_service | ||||
|     profiles: ["comfy"] | ||||
| @@ -69,11 +53,3 @@ services: | ||||
|     deploy: {} | ||||
|     environment: | ||||
|       - 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 \ | ||||
|   git clone https://github.com/AUTOMATIC1111/stable-diffusion-webui.git && \ | ||||
|   cd stable-diffusion-webui && \ | ||||
|   git reset --hard v1.9.3 && \ | ||||
|   git reset --hard v1.9.4 && \ | ||||
|   pip install -r requirements_versions.txt | ||||
|  | ||||
|  | ||||
|   | ||||
| @@ -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