stable-diffusion-webui/webui.sh

277 lines
8.7 KiB
Bash
Raw Normal View History

#!/usr/bin/env bash
2022-09-13 21:28:04 +08:00
#################################################
# Please do not make any changes to this file, #
# change the variables in webui-user.sh instead #
#################################################
2022-10-08 03:25:01 +08:00
SCRIPT_DIR=$( cd -- "$( dirname -- "${BASH_SOURCE[0]}" )" &> /dev/null && pwd )
# If run from macOS, load defaults from webui-macos-env.sh
if [[ "$OSTYPE" == "darwin"* ]]; then
if [[ -f "$SCRIPT_DIR"/webui-macos-env.sh ]]
then
source "$SCRIPT_DIR"/webui-macos-env.sh
fi
fi
2022-09-13 21:28:04 +08:00
# Read variables from webui-user.sh
# shellcheck source=/dev/null
if [[ -f "$SCRIPT_DIR"/webui-user.sh ]]
2022-09-13 21:28:04 +08:00
then
source "$SCRIPT_DIR"/webui-user.sh
2022-09-13 21:28:04 +08:00
fi
2023-03-13 01:50:02 +08:00
2023-10-02 15:43:59 +08:00
# If $venv_dir is "-", then disable venv support
use_venv=1
if [[ $venv_dir == "-" ]]; then
use_venv=0
fi
2022-09-13 21:28:04 +08:00
# Set defaults
# Install directory without trailing slash
if [[ -z "${install_dir}" ]]
then
2023-07-03 15:17:27 +08:00
install_dir="$SCRIPT_DIR"
2022-09-13 21:28:04 +08:00
fi
# Name of the subdirectory (defaults to stable-diffusion-webui)
if [[ -z "${clone_dir}" ]]
then
clone_dir="stable-diffusion-webui"
fi
# python3 executable
if [[ -z "${python_cmd}" ]]
then
python_cmd="python3"
fi
# git executable
2022-09-13 23:28:54 +08:00
if [[ -z "${GIT}" ]]
2022-09-13 21:28:04 +08:00
then
2022-09-13 23:28:54 +08:00
export GIT="git"
else
export GIT_PYTHON_GIT_EXECUTABLE="${GIT}"
2022-09-13 21:28:04 +08:00
fi
# python3 venv without trailing slash (defaults to ${install_dir}/${clone_dir}/venv)
2023-07-19 06:48:21 +08:00
if [[ -z "${venv_dir}" ]] && [[ $use_venv -eq 1 ]]
2022-09-13 21:28:04 +08:00
then
2023-03-13 01:50:02 +08:00
venv_dir="venv"
2022-09-13 21:28:04 +08:00
fi
2022-09-30 17:44:08 +08:00
if [[ -z "${LAUNCH_SCRIPT}" ]]
2022-09-30 16:51:05 +08:00
then
2023-03-13 01:50:02 +08:00
LAUNCH_SCRIPT="launch.py"
2022-09-30 16:51:05 +08:00
fi
2022-10-08 03:25:01 +08:00
# this script cannot be run as root by default
can_run_as_root=0
# read any command line flags to the webui.sh script
while getopts "f" flag > /dev/null 2>&1
2022-10-08 03:25:01 +08:00
do
case ${flag} in
f) can_run_as_root=1;;
*) break;;
2022-10-08 03:25:01 +08:00
esac
done
2022-09-26 18:55:10 +08:00
# Disable sentry logging
export ERROR_REPORTING=FALSE
2022-09-13 21:28:04 +08:00
# Do not reinstall existing pip packages on Debian/Ubuntu
export PIP_IGNORE_INSTALLED=0
# Pretty print
delimiter="################################################################"
printf "\n%s\n" "${delimiter}"
printf "\e[1m\e[32mInstall script for stable-diffusion + Web UI\n"
printf "\e[1m\e[34mTested on Debian 11 (Bullseye), Fedora 34+ and openSUSE Leap 15.4 or newer.\e[0m"
2022-09-13 21:28:04 +08:00
printf "\n%s\n" "${delimiter}"
# Do not run as root
2022-10-08 03:25:01 +08:00
if [[ $(id -u) -eq 0 && can_run_as_root -eq 0 ]]
2022-09-13 21:28:04 +08:00
then
printf "\n%s\n" "${delimiter}"
printf "\e[1m\e[31mERROR: This script must not be launched as root, aborting...\e[0m"
printf "\n%s\n" "${delimiter}"
exit 1
else
printf "\n%s\n" "${delimiter}"
printf "Running on \e[1m\e[32m%s\e[0m user" "$(whoami)"
printf "\n%s\n" "${delimiter}"
fi
2023-05-18 12:35:24 +08:00
if [[ $(getconf LONG_BIT) = 32 ]]
then
printf "\n%s\n" "${delimiter}"
printf "\e[1m\e[31mERROR: Unsupported Running on a 32bit OS\e[0m"
printf "\n%s\n" "${delimiter}"
exit 1
fi
2022-09-13 21:28:04 +08:00
if [[ -d .git ]]
then
printf "\n%s\n" "${delimiter}"
printf "Repo already cloned, using it as install directory"
printf "\n%s\n" "${delimiter}"
install_dir="${PWD}/../"
clone_dir="${PWD##*/}"
fi
# Check prerequisites
gpu_info=$(lspci 2>/dev/null | grep -E "VGA|Display")
case "$gpu_info" in
*"Navi 1"*)
export HSA_OVERRIDE_GFX_VERSION=10.3.0
if [[ -z "${TORCH_COMMAND}" ]]
then
pyv="$(${python_cmd} -c 'import sys; print(".".join(map(str, sys.version_info[0:2])))')"
if [[ $(bc <<< "$pyv <= 3.10") -eq 1 ]]
then
# Navi users will still use torch 1.13 because 2.0 does not seem to work.
2023-12-13 09:39:14 +08:00
export TORCH_COMMAND="pip install --pre torch torchvision --index-url https://download.pytorch.org/whl/nightly/rocm5.6"
else
printf "\e[1m\e[31mERROR: RX 5000 series GPUs must be using at max python 3.10, aborting...\e[0m"
exit 1
fi
fi
;;
*"Navi 2"*) export HSA_OVERRIDE_GFX_VERSION=10.3.0
;;
*"Navi 3"*) [[ -z "${TORCH_COMMAND}" ]] && \
2023-12-13 09:39:14 +08:00
export TORCH_COMMAND="pip install --pre torch torchvision --index-url https://download.pytorch.org/whl/nightly/rocm5.7"
;;
*"Renoir"*) export HSA_OVERRIDE_GFX_VERSION=9.0.0
printf "\n%s\n" "${delimiter}"
printf "Experimental support for Renoir: make sure to have at least 4GB of VRAM and 10GB of RAM or enable cpu mode: --use-cpu all --no-half"
printf "\n%s\n" "${delimiter}"
;;
2023-04-13 07:46:59 +08:00
*)
;;
esac
if ! echo "$gpu_info" | grep -q "NVIDIA";
2023-01-20 02:23:40 +08:00
then
if echo "$gpu_info" | grep -q "AMD" && [[ -z "${TORCH_COMMAND}" ]]
then
2023-05-26 17:09:09 +08:00
export TORCH_COMMAND="pip install torch==2.0.1+rocm5.4.2 torchvision==0.15.2+rocm5.4.2 --index-url https://download.pytorch.org/whl/rocm5.4.2"
2024-01-27 17:21:32 +08:00
elif echo "$gpu_info" | grep -q "Huawei" && [[ -z "${TORCH_COMMAND}" ]]
then
export TORCH_COMMAND="pip install torch==2.1.0 torchvision torchaudio --index-url https://download.pytorch.org/whl/cpu; pip install torch_npu"
fi
2023-05-18 12:35:24 +08:00
fi
2023-01-20 02:21:02 +08:00
for preq in "${GIT}" "${python_cmd}"
2022-09-13 21:28:04 +08:00
do
if ! hash "${preq}" &>/dev/null
then
printf "\n%s\n" "${delimiter}"
printf "\e[1m\e[31mERROR: %s is not installed, aborting...\e[0m" "${preq}"
printf "\n%s\n" "${delimiter}"
exit 1
fi
done
2023-07-19 06:48:21 +08:00
if [[ $use_venv -eq 1 ]] && ! "${python_cmd}" -c "import venv" &>/dev/null
2022-09-13 21:28:04 +08:00
then
printf "\n%s\n" "${delimiter}"
printf "\e[1m\e[31mERROR: python3-venv is not installed, aborting...\e[0m"
printf "\n%s\n" "${delimiter}"
exit 1
fi
2023-03-13 01:50:02 +08:00
cd "${install_dir}"/ || { printf "\e[1m\e[31mERROR: Can't cd to %s/, aborting...\e[0m" "${install_dir}"; exit 1; }
if [[ -d "${clone_dir}" ]]
2022-09-13 21:28:04 +08:00
then
2023-03-13 01:50:02 +08:00
cd "${clone_dir}"/ || { printf "\e[1m\e[31mERROR: Can't cd to %s/%s/, aborting...\e[0m" "${install_dir}" "${clone_dir}"; exit 1; }
else
2022-10-24 22:13:25 +08:00
printf "\n%s\n" "${delimiter}"
printf "Clone stable-diffusion-webui"
printf "\n%s\n" "${delimiter}"
2023-03-13 01:50:02 +08:00
"${GIT}" clone https://github.com/AUTOMATIC1111/stable-diffusion-webui.git "${clone_dir}"
cd "${clone_dir}"/ || { printf "\e[1m\e[31mERROR: Can't cd to %s/%s/, aborting...\e[0m" "${install_dir}" "${clone_dir}"; exit 1; }
2022-09-13 21:28:04 +08:00
fi
2023-07-19 06:48:21 +08:00
if [[ $use_venv -eq 1 ]] && [[ -z "${VIRTUAL_ENV}" ]];
2022-09-13 21:28:04 +08:00
then
printf "\n%s\n" "${delimiter}"
printf "Create and activate python venv"
printf "\n%s\n" "${delimiter}"
cd "${install_dir}"/"${clone_dir}"/ || { printf "\e[1m\e[31mERROR: Can't cd to %s/%s/, aborting...\e[0m" "${install_dir}" "${clone_dir}"; exit 1; }
if [[ ! -d "${venv_dir}" ]]
then
"${python_cmd}" -m venv "${venv_dir}"
first_launch=1
fi
# shellcheck source=/dev/null
if [[ -f "${venv_dir}"/bin/activate ]]
then
source "${venv_dir}"/bin/activate
else
printf "\n%s\n" "${delimiter}"
printf "\e[1m\e[31mERROR: Cannot activate python venv, aborting...\e[0m"
printf "\n%s\n" "${delimiter}"
exit 1
fi
2022-09-13 21:28:04 +08:00
else
printf "\n%s\n" "${delimiter}"
printf "python venv already activate or run without venv: ${VIRTUAL_ENV}"
2022-09-13 21:28:04 +08:00
printf "\n%s\n" "${delimiter}"
fi
2023-04-13 07:46:59 +08:00
# Try using TCMalloc on Linux
prepare_tcmalloc() {
if [[ "${OSTYPE}" == "linux"* ]] && [[ -z "${NO_TCMALLOC}" ]] && [[ -z "${LD_PRELOAD}" ]]; then
# Define Tcmalloc Libs arrays
TCMALLOC_LIBS=("libtcmalloc(_minimal|)\.so\.\d" "libtcmalloc\.so\.\d")
# Traversal array
for lib in "${TCMALLOC_LIBS[@]}"
do
#Determine which type of tcmalloc library the library supports
TCMALLOC="$(PATH=/usr/sbin:$PATH ldconfig -p | grep -P $lib | head -n 1)"
TC_INFO=(${TCMALLOC//=>/})
if [[ ! -z "${TC_INFO}" ]]; then
echo "Using TCMalloc: ${TC_INFO}"
#Determine if the library is linked to libptthread and resolve undefined symbol: ptthread_Key_Create
if ldd ${TC_INFO[2]} | grep -q 'libpthread'; then
echo "$TC_INFO is linked with libpthread,execute LD_PRELOAD=${TC_INFO}"
export LD_PRELOAD="${TC_INFO}"
break
else
echo "$TC_INFO is not linked with libpthreadand will trigger undefined symbol: ptthread_Key_Create error"
fi
else
printf "\e[1m\e[31mCannot locate TCMalloc (improves CPU memory usage)\e[0m\n"
fi
done
2023-04-13 07:46:59 +08:00
fi
}
2023-06-03 14:59:56 +08:00
KEEP_GOING=1
export SD_WEBUI_RESTART=tmp/restart
2023-06-03 14:59:56 +08:00
while [[ "$KEEP_GOING" -eq "1" ]]; do
if [[ ! -z "${ACCELERATE}" ]] && [ ${ACCELERATE}="True" ] && [ -x "$(command -v accelerate)" ]; then
printf "\n%s\n" "${delimiter}"
printf "Accelerating launch.py..."
printf "\n%s\n" "${delimiter}"
prepare_tcmalloc
accelerate launch --num_cpu_threads_per_process=6 "${LAUNCH_SCRIPT}" "$@"
else
printf "\n%s\n" "${delimiter}"
printf "Launching launch.py..."
printf "\n%s\n" "${delimiter}"
prepare_tcmalloc
"${python_cmd}" -u "${LAUNCH_SCRIPT}" "$@"
2023-06-03 14:59:56 +08:00
fi
if [[ ! -f tmp/restart ]]; then
KEEP_GOING=0
fi
done