5698c49653
- auto:050a6a798c
- Now uses python 3.10 - requires a complete re-install - Image is now smaller (5.7GB vs 9.8GB) - hlky:fe6e72fde7
- lstein:31869885d9
- img2img now works
78 lines
3.0 KiB
Docker
78 lines
3.0 KiB
Docker
# syntax=docker/dockerfile:1
|
|
|
|
FROM alpine/git:2.36.2 as download
|
|
|
|
|
|
RUN git clone https://github.com/CompVis/stable-diffusion.git repositories/stable-diffusion && cd repositories/stable-diffusion && git reset --hard 69ae4b35e0a0f6ee1af8bb9a5d0016ccb27e36dc
|
|
|
|
RUN git clone https://github.com/sczhou/CodeFormer.git repositories/CodeFormer && cd repositories/CodeFormer && git reset --hard c5b4593074ba6214284d6acd5f1719b6c5d739af
|
|
RUN git clone https://github.com/salesforce/BLIP.git repositories/BLIP && cd repositories/BLIP && git reset --hard 48211a1594f1321b00f14c9f7a5b4813144b2fb9
|
|
RUN git clone https://github.com/Hafiidz/latent-diffusion.git repositories/latent-diffusion && cd repositories/latent-diffusion && git reset --hard abf33e7002d59d9085081bce93ec798dcabd49af
|
|
|
|
RUN <<EOF
|
|
# because taming-transformers is huge
|
|
git config --global http.postBuffer 1048576000
|
|
git clone https://github.com/CompVis/taming-transformers.git repositories/taming-transformers
|
|
git reset --hard 24268930bf1dce879235a7fddd0b2355b84d7ea6
|
|
rm -rf repositories/taming-transformers/data repositories/taming-transformers/assets
|
|
EOF
|
|
|
|
RUN git clone https://github.com/crowsonkb/k-diffusion.git repositories/k-diffusion && cd repositories/k-diffusion && git reset --hard f4e99857772fc3a126ba886aadf795a332774878
|
|
|
|
|
|
FROM python:3.10-slim
|
|
|
|
SHELL ["/bin/bash", "-ceuxo", "pipefail"]
|
|
|
|
ENV DEBIAN_FRONTEND=noninteractive PIP_PREFER_BINARY=1 PIP_NO_CACHE_DIR=1
|
|
|
|
RUN pip install torch==1.12.1+cu113 torchvision==0.13.1+cu113 --extra-index-url https://download.pytorch.org/whl/cu113
|
|
|
|
RUN apt-get update && apt install fonts-dejavu-core rsync git -y && apt-get clean
|
|
|
|
|
|
RUN <<EOF
|
|
git clone https://github.com/AUTOMATIC1111/stable-diffusion-webui.git
|
|
cd stable-diffusion-webui
|
|
git reset --hard 1eb588cbf19924333b88beaa1ac0041904966640
|
|
pip install -r requirements_versions.txt
|
|
EOF
|
|
|
|
ENV ROOT=/stable-diffusion-webui \
|
|
WORKDIR=/stable-diffusion-webui/repositories/stable-diffusion
|
|
|
|
|
|
COPY --from=download /git/ ${ROOT}
|
|
RUN pip install --prefer-binary --no-cache-dir -r ${ROOT}/repositories/CodeFormer/requirements.txt
|
|
|
|
# Note: don't update the sha of previous versions because the install will take forever
|
|
# instead, update the repo state in a later step
|
|
|
|
ARG SHA=050a6a798cec90ae2f881c2ddd3f0221e69907dc
|
|
RUN <<EOF
|
|
cd stable-diffusion-webui
|
|
git pull --rebase
|
|
git reset --hard ${SHA}
|
|
pip install --prefer-binary --no-cache-dir -r requirements_versions.txt
|
|
pip install --prefer-binary --no-cache-dir -r requirements.txt
|
|
EOF
|
|
|
|
RUN pip install --prefer-binary --no-cache-dir opencv-python-headless \
|
|
git+https://github.com/TencentARC/GFPGAN.git@8d2447a2d918f8eba5a4a01463fd48e45126a379 \
|
|
git+https://github.com/openai/CLIP.git@d50d76daa670286dd6cacf3bcd80b5e4823fc8e1
|
|
#xformers
|
|
|
|
|
|
|
|
COPY . /docker
|
|
RUN <<EOF
|
|
chmod +x /docker/mount.sh && python3 /docker/info.py ${ROOT}/modules/ui.py
|
|
EOF
|
|
|
|
ENV CLI_ARGS=""
|
|
WORKDIR ${WORKDIR}
|
|
EXPOSE 7860
|
|
# run, -u to not buffer stdout / stderr
|
|
CMD /docker/mount.sh && \
|
|
python3 -u ../../webui.py --listen --port 7860 --hide-ui-dir-config --ckpt-dir ${ROOT}/models/Stable-diffusion ${CLI_ARGS}
|