mirror of
https://github.com/invoke-ai/InvokeAI.git
synced 2025-01-07 03:17:05 +08:00
47 lines
1.6 KiB
Bash
Executable File
47 lines
1.6 KiB
Bash
Executable File
#!/bin/bash
|
|
set -e -o pipefail
|
|
|
|
### Container entrypoint
|
|
# Runs the CMD as defined by the Dockerfile or passed to `docker run`
|
|
# Can be used to configure the runtime dir
|
|
# Bypass by using ENTRYPOINT or `--entrypoint`
|
|
|
|
### Set INVOKEAI_ROOT pointing to a valid runtime directory
|
|
# Otherwise configure the runtime dir first.
|
|
|
|
### Set the CONTAINER_UID envvar to match your user.
|
|
# Ensures files created in the container are owned by you:
|
|
# docker run --rm -it -v /some/path:/invokeai -e CONTAINER_UID=$(id -u) <this image>
|
|
# Default UID: 1000 chosen due to popularity on Linux systems. Possibly 501 on MacOS.
|
|
|
|
USER_ID=${CONTAINER_UID:-1000}
|
|
USER=ubuntu
|
|
# if the user does not exist, create it. It is expected to be present on ubuntu >=24.x
|
|
_=$(id ${USER} 2>&1) || useradd -u ${USER_ID} ${USER}
|
|
# ensure the UID is correct
|
|
usermod -u ${USER_ID} ${USER} 1>/dev/null
|
|
|
|
### Set the $PUBLIC_KEY env var to enable SSH access.
|
|
# We do not install openssh-server in the image by default to avoid bloat.
|
|
# but it is useful to have the full SSH server e.g. on Runpod.
|
|
# (use SCP to copy files to/from the image, etc)
|
|
if [[ -v "PUBLIC_KEY" ]] && [[ ! -d "${HOME}/.ssh" ]]; then
|
|
apt-get update
|
|
apt-get install -y openssh-server
|
|
pushd "$HOME"
|
|
mkdir -p .ssh
|
|
echo "${PUBLIC_KEY}" >.ssh/authorized_keys
|
|
chmod -R 700 .ssh
|
|
popd
|
|
service ssh start
|
|
fi
|
|
|
|
mkdir -p "${INVOKEAI_ROOT}"
|
|
chown --recursive ${USER} "${INVOKEAI_ROOT}" || true
|
|
cd "${INVOKEAI_ROOT}"
|
|
export HF_HOME=${HF_HOME:-$INVOKEAI_ROOT/.cache/huggingface}
|
|
export MPLCONFIGDIR=${MPLCONFIGDIR:-$INVOKEAI_ROOT/.matplotlib}
|
|
|
|
# Run the CMD as the Container User (not root).
|
|
exec gosu ${USER} "$@"
|