mirror of
https://github.com/AbdBarho/stable-diffusion-webui-docker.git
synced 2026-02-06 07:34:18 +01:00
commit
cdbfb4ec89
|
|
@ -65,7 +65,7 @@ RUN if [ "$PUID" -ne "0" ]; then \
|
||||||
fi
|
fi
|
||||||
|
|
||||||
WORKDIR /
|
WORKDIR /
|
||||||
RUN --mount=type=cache,target=/root/.cache/pip \
|
RUN --mount=type=cache,target=${USER_HOME}/.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.10.1 && \
|
git reset --hard v1.10.1 && \
|
||||||
|
|
@ -82,7 +82,7 @@ ENV ROOT=/stable-diffusion-webui
|
||||||
COPY --from=download --chown=${PUID}:${PGID} /repositories/ ${ROOT}/repositories/
|
COPY --from=download --chown=${PUID}:${PGID} /repositories/ ${ROOT}/repositories/
|
||||||
RUN mkdir ${ROOT}/interrogate && cp ${ROOT}/repositories/clip-interrogator/clip_interrogator/data/* ${ROOT}/interrogate
|
RUN mkdir ${ROOT}/interrogate && cp ${ROOT}/repositories/clip-interrogator/clip_interrogator/data/* ${ROOT}/interrogate
|
||||||
|
|
||||||
RUN --mount=type=cache,target=/root/.cache/pip \
|
RUN --mount=type=cache,target=${USER_HOME}/.cache/pip \
|
||||||
pip install pyngrok xformers==0.0.26.post1 \
|
pip install pyngrok xformers==0.0.26.post1 \
|
||||||
git+https://github.com/TencentARC/GFPGAN.git@8d2447a2d918f8eba5a4a01463fd48e45126a379 \
|
git+https://github.com/TencentARC/GFPGAN.git@8d2447a2d918f8eba5a4a01463fd48e45126a379 \
|
||||||
git+https://github.com/openai/CLIP.git@d50d76daa670286dd6cacf3bcd80b5e4823fc8e1 \
|
git+https://github.com/openai/CLIP.git@d50d76daa670286dd6cacf3bcd80b5e4823fc8e1 \
|
||||||
|
|
@ -90,11 +90,10 @@ RUN --mount=type=cache,target=/root/.cache/pip \
|
||||||
|
|
||||||
# there seems to be a memory leak (or maybe just memory not being freed fast enough) that is fixed by this version of malloc
|
# there seems to be a memory leak (or maybe just memory not being freed fast enough) that is fixed by this version of malloc
|
||||||
# maybe move this up to the dependencies list.
|
# maybe move this up to the dependencies list.
|
||||||
RUN apt-get -y install libgoogle-perftools-dev && apt-get clean
|
|
||||||
ENV LD_PRELOAD=libtcmalloc.so
|
ENV LD_PRELOAD=libtcmalloc.so
|
||||||
|
|
||||||
COPY . /docker
|
COPY . /docker
|
||||||
|
COPY --chown=$PUID:$PGID . /docker
|
||||||
RUN \
|
RUN \
|
||||||
# mv ${ROOT}/style.css ${ROOT}/user.css && \
|
# mv ${ROOT}/style.css ${ROOT}/user.css && \
|
||||||
# one of the ugliest hacks I ever wrote \
|
# one of the ugliest hacks I ever wrote \
|
||||||
|
|
|
||||||
|
|
@ -2,10 +2,50 @@ FROM pytorch/pytorch:2.3.0-cuda12.1-cudnn8-runtime
|
||||||
|
|
||||||
ENV DEBIAN_FRONTEND=noninteractive PIP_PREFER_BINARY=1
|
ENV DEBIAN_FRONTEND=noninteractive PIP_PREFER_BINARY=1
|
||||||
|
|
||||||
RUN apt-get update && apt-get install -y git && apt-get clean
|
RUN apt-get update && apt-get install -y git libgoogle-perftools-dev && apt-get clean
|
||||||
|
|
||||||
|
ARG PUID=0
|
||||||
|
ARG PGID=0
|
||||||
|
ARG USER_HOME=/root
|
||||||
|
# set build args as container environment variables for entrypoint reference
|
||||||
|
ENV PUID=$PUID
|
||||||
|
ENV PGID=$PGID
|
||||||
|
ENV USER_HOME=$USER_HOME
|
||||||
|
|
||||||
|
# if user home does not exist, create it
|
||||||
|
RUN mkdir -p "$USER_HOME"
|
||||||
|
|
||||||
|
# home already exists, chown it
|
||||||
|
RUN chown -R "${PUID}:${PGID}" "$USER_HOME"
|
||||||
|
|
||||||
|
# Only groupadd if we're non root
|
||||||
|
RUN if [ "$PGID" -ne "0" ]; then \
|
||||||
|
echo non root group detected; \
|
||||||
|
groupadd \
|
||||||
|
--gid "$PGID" \
|
||||||
|
stablediffusion ;\
|
||||||
|
else \
|
||||||
|
echo "root group detected" ; \
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Only useradd if we're non root
|
||||||
|
RUN if [ "$PUID" -ne "0" ]; then \
|
||||||
|
echo non root user detected; \
|
||||||
|
useradd \
|
||||||
|
--gid="$PGID" \
|
||||||
|
--no-user-group \
|
||||||
|
-M \
|
||||||
|
--home "$USER_HOME" \
|
||||||
|
stablediffusion ; \
|
||||||
|
else \
|
||||||
|
echo "root group detected" ; \
|
||||||
|
fi
|
||||||
|
|
||||||
|
RUN chown -R "$PUID:$PGID" /stable-diffusion
|
||||||
|
USER $PUID:$PGID
|
||||||
|
|
||||||
ENV ROOT=/stable-diffusion
|
ENV ROOT=/stable-diffusion
|
||||||
RUN --mount=type=cache,target=/root/.cache/pip \
|
RUN --mount=type=cache,target="$USER_HOME"/.cache/pip \
|
||||||
git clone https://github.com/comfyanonymous/ComfyUI.git ${ROOT} && \
|
git clone https://github.com/comfyanonymous/ComfyUI.git ${ROOT} && \
|
||||||
cd ${ROOT} && \
|
cd ${ROOT} && \
|
||||||
git checkout master && \
|
git checkout master && \
|
||||||
|
|
|
||||||
|
|
@ -6,7 +6,7 @@ mkdir -vp /data/config/comfy/custom_nodes
|
||||||
|
|
||||||
declare -A MOUNTS
|
declare -A MOUNTS
|
||||||
|
|
||||||
MOUNTS["/root/.cache"]="/data/.cache"
|
MOUNTS["${USER_HOME}/.cache"]="/data/.cache"
|
||||||
MOUNTS["${ROOT}/input"]="/data/config/comfy/input"
|
MOUNTS["${ROOT}/input"]="/data/config/comfy/input"
|
||||||
MOUNTS["${ROOT}/output"]="/output/comfy"
|
MOUNTS["${ROOT}/output"]="/output/comfy"
|
||||||
|
|
||||||
|
|
@ -28,4 +28,9 @@ if [ -f "/data/config/comfy/startup.sh" ]; then
|
||||||
popd
|
popd
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
chown -R root ~/.cache/
|
||||||
|
chmod 766 ~/.cache/
|
||||||
|
chown -R $PUID:$PGID ~/.cache/
|
||||||
|
chmod 776 ~/.cache/
|
||||||
|
|
||||||
exec "$@"
|
exec "$@"
|
||||||
|
|
|
||||||
|
|
@ -6,17 +6,57 @@ FROM pytorch/pytorch:2.0.1-cuda11.7-cudnn8-runtime
|
||||||
|
|
||||||
ENV DEBIAN_FRONTEND=noninteractive PIP_PREFER_BINARY=1
|
ENV DEBIAN_FRONTEND=noninteractive PIP_PREFER_BINARY=1
|
||||||
|
|
||||||
RUN apt-get update && apt-get install -y git && apt-get clean
|
RUN apt-get update && apt-get install -y git libglib2.0-0 libgl1-mesa-glx python-dev libgoogle-perftools-dev && apt-get clean
|
||||||
|
|
||||||
|
ARG PUID=0
|
||||||
|
ARG PGID=0
|
||||||
|
ARG USER_HOME=/root
|
||||||
|
# set build args as container environment variables for entrypoint reference
|
||||||
|
ENV PUID=$PUID
|
||||||
|
ENV PGID=$PGID
|
||||||
|
ENV USER_HOME=$USER_HOME
|
||||||
|
|
||||||
|
# if user home does not exist, create it
|
||||||
|
RUN mkdir -p "$USER_HOME"
|
||||||
|
|
||||||
|
# home already exists, chown it
|
||||||
|
RUN chown -R "${PUID}:${PGID}" "$USER_HOME"
|
||||||
|
|
||||||
|
# Only groupadd if we're non root
|
||||||
|
RUN if [ "$PGID" -ne "0" ]; then \
|
||||||
|
echo non root group detected; \
|
||||||
|
groupadd \
|
||||||
|
--gid "$PGID" \
|
||||||
|
stablediffusion ;\
|
||||||
|
else \
|
||||||
|
echo "root group detected" ; \
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Only useradd if we're non root
|
||||||
|
RUN if [ "$PUID" -ne "0" ]; then \
|
||||||
|
echo non root user detected; \
|
||||||
|
useradd \
|
||||||
|
--gid="$PGID" \
|
||||||
|
--no-user-group \
|
||||||
|
-M \
|
||||||
|
--home "$USER_HOME" \
|
||||||
|
stablediffusion ; \
|
||||||
|
else \
|
||||||
|
echo "root group detected" ; \
|
||||||
|
fi
|
||||||
|
|
||||||
|
|
||||||
# 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
|
# set this to your target branch commit
|
||||||
ARG BRANCH=main SHA=e2f9bcb11d06216d6800676c48d8d74d6fd77a4b
|
ARG BRANCH=main SHA=e2f9bcb11d06216d6800676c48d8d74d6fd77a4b
|
||||||
|
|
||||||
ENV ROOT=/stable-diffusion
|
ENV ROOT=/stable-diffusion
|
||||||
|
|
||||||
|
RUN chown -R "$PUID:$PGID" /stable-diffusion-webui
|
||||||
|
|
||||||
|
# drop permissions (if build targets non root)
|
||||||
|
USER $PUID:$PGID
|
||||||
|
|
||||||
RUN --mount=type=cache,target=/root/.cache/pip \
|
RUN --mount=type=cache,target=/root/.cache/pip \
|
||||||
git clone https://github.com/lllyasviel/Fooocus.git ${ROOT} && \
|
git clone https://github.com/lllyasviel/Fooocus.git ${ROOT} && \
|
||||||
cd ${ROOT} && \
|
cd ${ROOT} && \
|
||||||
|
|
@ -38,7 +78,7 @@ RUN --mount=type=cache,target=/root/.cache/pip \
|
||||||
pip install -r requirements_versions.txt
|
pip install -r requirements_versions.txt
|
||||||
|
|
||||||
# add info
|
# add info
|
||||||
COPY . /docker/
|
COPY --chown=$PUID:$PGID . /docker
|
||||||
RUN cp /docker/config.txt ${ROOT}
|
RUN cp /docker/config.txt ${ROOT}
|
||||||
RUN chmod u+x /docker/entrypoint.sh
|
RUN chmod u+x /docker/entrypoint.sh
|
||||||
|
|
||||||
|
|
|
||||||
Loading…
Reference in a new issue