Debloat-docker (#1612)

* debloat Dockerfile
- less options more but more userfriendly
- better Entrypoint to simulate CLI usage
- without command the container still starts the web-host

* debloat build.sh

* better syntax in run.sh

* update Docker docs
- fix description of VOLUMENAME
- update run script example to reflect new entrypoint
This commit is contained in:
Matthias Wild 2022-11-29 16:04:03 +01:00 committed by GitHub
parent f43b767b87
commit 5897e511f1
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 27 additions and 46 deletions

View File

@ -18,24 +18,17 @@ RUN apt-get update \
&& apt-get clean \ && apt-get clean \
&& rm -rf /var/lib/apt/lists/* && rm -rf /var/lib/apt/lists/*
ARG PIP_REQUIREMENTS=requirements-lin-cuda.txt
ARG PROJECT_NAME=invokeai
ARG INVOKEAI_ROOT=/data
ENV INVOKEAI_ROOT=${INVOKEAI_ROOT}
# set workdir and copy sources # set workdir and copy sources
WORKDIR /${PROJECT_NAME} WORKDIR /invokeai
COPY . . ARG PIP_REQUIREMENTS=requirements-lin-cuda.txt
COPY . ./environments-and-requirements/${PIP_REQUIREMENTS} ./
# install requirements and link outputs folder # install requirements and link outputs folder
RUN cp \ RUN pip install \
./environments-and-requirements/${PIP_REQUIREMENTS} \ --no-cache-dir \
${PIP_REQUIREMENTS} \ -r ${PIP_REQUIREMENTS}
&& pip install \
--no-cache-dir \
-r ${PIP_REQUIREMENTS} \
&& ln -sf /data/outputs /${PROJECT_NAME}/outputs
# set Entrypoint and default CMD # set Environment, Entrypoint and default CMD
ENTRYPOINT [ "python3" ] ENV INVOKEAI_ROOT /data
CMD [ "scripts/invoke.py", "--web", "--host", "0.0.0.0" ] ENTRYPOINT [ "python3", "scripts/invoke.py", "--outdir=/data/outputs" ]
CMD [ "--web", "--host=0.0.0.0" ]

View File

@ -1,10 +1,12 @@
#!/usr/bin/env bash #!/usr/bin/env bash
set -e set -e
# IMPORTANT: You need to have a token on huggingface.co to be able to download the checkpoint!!!
# configure values by using env when executing build.sh
# f.e. env ARCH=aarch64 GITHUB_INVOKE_AI=https://github.com/yourname/yourfork.git ./build.sh
source ./docker-build/env.sh || echo "please run from repository root" || exit 1 # IMPORTANT: You need to have a token on huggingface.co to be able to download the checkpoints!!!
# configure values by using env when executing build.sh f.e. `env ARCH=aarch64 ./build.sh`
source ./docker-build/env.sh \
|| echo "please execute docker-build/build.sh from repository root" \
|| exit 1
pip_requirements=${PIP_REQUIREMENTS:-requirements-lin-cuda.txt} pip_requirements=${PIP_REQUIREMENTS:-requirements-lin-cuda.txt}
dockerfile=${INVOKE_DOCKERFILE:-docker-build/Dockerfile} dockerfile=${INVOKE_DOCKERFILE:-docker-build/Dockerfile}
@ -13,28 +15,14 @@ dockerfile=${INVOKE_DOCKERFILE:-docker-build/Dockerfile}
echo "You are using these values:" echo "You are using these values:"
echo -e "Dockerfile:\t\t ${dockerfile}" echo -e "Dockerfile:\t\t ${dockerfile}"
echo -e "requirements:\t\t ${pip_requirements}" echo -e "requirements:\t\t ${pip_requirements}"
echo -e "project_name:\t\t ${project_name}"
echo -e "volumename:\t\t ${volumename}" echo -e "volumename:\t\t ${volumename}"
echo -e "arch:\t\t\t ${arch}" echo -e "arch:\t\t\t ${arch}"
echo -e "platform:\t\t ${platform}" echo -e "platform:\t\t ${platform}"
echo -e "invokeai_tag:\t\t ${invokeai_tag}\n" echo -e "invokeai_tag:\t\t ${invokeai_tag}\n"
_runAlpine() {
docker run \
--rm \
--interactive \
--tty \
--mount source="$volumename",target=/data \
--workdir /data \
alpine "$@"
}
_checkVolumeContent() {
_runAlpine ls -lhA /data/models
}
if [[ -n "$(docker volume ls -f name="${volumename}" -q)" ]]; then if [[ -n "$(docker volume ls -f name="${volumename}" -q)" ]]; then
echo "Volume already exists" echo "Volume already exists"
echo
else else
echo -n "createing docker volume " echo -n "createing docker volume "
docker volume create "${volumename}" docker volume create "${volumename}"
@ -44,7 +32,6 @@ fi
docker build \ docker build \
--platform="${platform}" \ --platform="${platform}" \
--tag="${invokeai_tag}" \ --tag="${invokeai_tag}" \
--build-arg="PROJECT_NAME=${project_name}" \
--build-arg="PIP_REQUIREMENTS=${pip_requirements}" \ --build-arg="PIP_REQUIREMENTS=${pip_requirements}" \
--file="${dockerfile}" \ --file="${dockerfile}" \
. .
@ -57,5 +44,6 @@ docker run \
--mount="source=$volumename,target=/data" \ --mount="source=$volumename,target=/data" \
--mount="type=bind,source=$HOME/.huggingface,target=/root/.huggingface" \ --mount="type=bind,source=$HOME/.huggingface,target=/root/.huggingface" \
--env="HUGGINGFACE_TOKEN=${HUGGINGFACE_TOKEN}" \ --env="HUGGINGFACE_TOKEN=${HUGGINGFACE_TOKEN}" \
--entrypoint="python3" \
"${invokeai_tag}" \ "${invokeai_tag}" \
scripts/configure_invokeai.py --yes scripts/configure_invokeai.py --yes

View File

@ -7,9 +7,9 @@ docker run \
--interactive \ --interactive \
--tty \ --tty \
--rm \ --rm \
--platform "$platform" \ --platform="$platform" \
--name "$project_name" \ --name="$project_name" \
--hostname "$project_name" \ --hostname="$project_name" \
--mount source="$volumename",target=/data \ --mount="source=$volumename,target=/data" \
--publish 9090:9090 \ --publish=9090:9090 \
"$invokeai_tag" ${1:+$@} "$invokeai_tag" ${1:+$@}

View File

@ -78,7 +78,7 @@ Some Suggestions of variables you may want to change besides the Token:
| -------------------- | ----------------------------- | -------------------------------------------------------------------------------------------- | | -------------------- | ----------------------------- | -------------------------------------------------------------------------------------------- |
| `HUGGINGFACE_TOKEN` | No default, but **required**! | This is the only **required** variable, without it you can't download the huggingface models | | `HUGGINGFACE_TOKEN` | No default, but **required**! | This is the only **required** variable, without it you can't download the huggingface models |
| `PROJECT_NAME` | `invokeai` | affects the project folder, tag- and volume name | | `PROJECT_NAME` | `invokeai` | affects the project folder, tag- and volume name |
| `VOLUMENAME` | `${PROJECT_NAME}_data` | affects the project folder, tag- and volume name | | `VOLUMENAME` | `${PROJECT_NAME}_data` | Name of the Docker Volume where model files will be stored |
| `ARCH` | `x86_64` | can be changed to f.e. aarch64 if you are using a ARM based CPU | | `ARCH` | `x86_64` | can be changed to f.e. aarch64 if you are using a ARM based CPU |
| `INVOKEAI_TAG` | `${PROJECT_NAME}:${ARCH}` | the Container Repository / Tag which will be used | | `INVOKEAI_TAG` | `${PROJECT_NAME}:${ARCH}` | the Container Repository / Tag which will be used |
| `PIP_REQUIREMENTS` | `requirements-lin-cuda.txt` | the requirements file to use (from `environments-and-requirements`) | | `PIP_REQUIREMENTS` | `requirements-lin-cuda.txt` | the requirements file to use (from `environments-and-requirements`) |
@ -111,13 +111,13 @@ When used without arguments, the container will start the webserver and provide
you the link to open it. But if you want to use some other parameters you can you the link to open it. But if you want to use some other parameters you can
also do so. also do so.
!!! example "" !!! example "run script example"
```bash ```bash
./docker-build/run.sh scripts/invoke.py ./docker-build/run.sh "banana sushi" -Ak_lms -S42 -s10
``` ```
This would start the CLI instead of the default command that starts the webserver. This would generate the legendary "banana sushi" with Seed 42, k_lms Sampler and 10 steps.
Find out more about available CLI-Parameters at [features/CLI.md](../../features/CLI/#arguments) Find out more about available CLI-Parameters at [features/CLI.md](../../features/CLI/#arguments)