mirror of
https://github.com/invoke-ai/InvokeAI
synced 2024-08-30 20:32:17 +00:00
8819e12a86
This makes a cosmetic change. Instead of calling preload_models.py (deprecated) it calls configure_invokeai.py. Currently the two do the same thing.
144 lines
5.2 KiB
Bash
Executable File
144 lines
5.2 KiB
Bash
Executable File
#!/usr/bin/env bash
|
|
|
|
# This script will install git and conda (if not found on the PATH variable)
|
|
# using micromamba (an 8mb static-linked single-file binary, conda replacement).
|
|
# For users who already have git and conda, this step will be skipped.
|
|
|
|
# Next, it'll checkout the project's git repo, if necessary.
|
|
# Finally, it'll create the conda environment and configure InvokeAI.
|
|
|
|
# This enables a user to install this project without manually installing conda and git.
|
|
|
|
cd "$(dirname "${BASH_SOURCE[0]}")"
|
|
|
|
echo "InvokeAI source installer..."
|
|
echo ""
|
|
echo "Some of the installation steps take a long time to run. Please be patient."
|
|
echo "If the script appears to hang for more than 10 minutes, please interrupt with control-C and retry."
|
|
read -n 1 -s -r -p "<Press any key to start the install>"
|
|
echo ""
|
|
|
|
OS_NAME=$(uname -s)
|
|
case "${OS_NAME}" in
|
|
Linux*) OS_NAME="linux";;
|
|
Darwin*) OS_NAME="osx";;
|
|
*) echo "Unknown OS: $OS_NAME! This script runs only on Linux or Mac" && exit
|
|
esac
|
|
|
|
OS_ARCH=$(uname -m)
|
|
case "${OS_ARCH}" in
|
|
x86_64*) OS_ARCH="64";;
|
|
arm64*) OS_ARCH="arm64";;
|
|
*) echo "Unknown system architecture: $OS_ARCH! This script runs only on x86_64 or arm64" && exit
|
|
esac
|
|
|
|
# https://mamba.readthedocs.io/en/latest/installation.html
|
|
if [ "$OS_NAME" == "linux" ] && [ "$OS_ARCH" == "arm64" ]; then OS_ARCH="aarch64"; fi
|
|
|
|
# config
|
|
export MAMBA_ROOT_PREFIX="$(pwd)/installer_files/mamba"
|
|
INSTALL_ENV_DIR="$(pwd)/installer_files/env"
|
|
MICROMAMBA_DOWNLOAD_URL="https://micro.mamba.pm/api/micromamba/${OS_NAME}-${OS_ARCH}/latest"
|
|
REPO_URL="https://github.com/invoke-ai/InvokeAI.git"
|
|
umamba_exists="F"
|
|
|
|
# figure out whether git and conda needs to be installed
|
|
if [ -e "$INSTALL_ENV_DIR" ]; then export PATH="$INSTALL_ENV_DIR/bin:$PATH"; fi
|
|
|
|
PACKAGES_TO_INSTALL=""
|
|
if ! $(which conda) -V &>/dev/null; then PACKAGES_TO_INSTALL="$PACKAGES_TO_INSTALL conda"; fi
|
|
if ! which git &>/dev/null; then PACKAGES_TO_INSTALL="$PACKAGES_TO_INSTALL git"; fi
|
|
|
|
if "$MAMBA_ROOT_PREFIX/micromamba" --version &>/dev/null; then umamba_exists="T"; fi
|
|
|
|
# (if necessary) install git and conda into a contained environment
|
|
if [ "$PACKAGES_TO_INSTALL" != "" ]; then
|
|
# download micromamba
|
|
if [ "$umamba_exists" == "F" ]; then
|
|
echo "Downloading micromamba from $MICROMAMBA_DOWNLOAD_URL to $MAMBA_ROOT_PREFIX/micromamba"
|
|
|
|
mkdir -p "$MAMBA_ROOT_PREFIX"
|
|
curl -L "$MICROMAMBA_DOWNLOAD_URL" | tar -xvjO bin/micromamba > "$MAMBA_ROOT_PREFIX/micromamba"
|
|
|
|
chmod u+x "$MAMBA_ROOT_PREFIX/micromamba"
|
|
|
|
# test the mamba binary
|
|
echo "Micromamba version:"
|
|
"$MAMBA_ROOT_PREFIX/micromamba" --version
|
|
fi
|
|
|
|
# create the installer env
|
|
if [ ! -e "$INSTALL_ENV_DIR" ]; then
|
|
"$MAMBA_ROOT_PREFIX/micromamba" create -y --prefix "$INSTALL_ENV_DIR"
|
|
fi
|
|
|
|
echo "Packages to install:$PACKAGES_TO_INSTALL"
|
|
|
|
"$MAMBA_ROOT_PREFIX/micromamba" install -y --prefix "$INSTALL_ENV_DIR" -c conda-forge $PACKAGES_TO_INSTALL
|
|
|
|
if [ ! -e "$INSTALL_ENV_DIR" ]; then
|
|
echo "There was a problem while initializing micromamba. Cannot continue."
|
|
exit
|
|
fi
|
|
fi
|
|
|
|
if [ -e "$INSTALL_ENV_DIR" ]; then export PATH="$INSTALL_ENV_DIR/bin:$PATH"; fi
|
|
|
|
# get the repo (and load into the current directory)
|
|
if [ ! -e ".git" ]; then
|
|
git init
|
|
git config --local init.defaultBranch main
|
|
git remote add origin "$REPO_URL"
|
|
git fetch
|
|
git checkout origin/main -ft
|
|
fi
|
|
|
|
# create the environment
|
|
CONDA_BASEPATH=$(conda info --base)
|
|
source "$CONDA_BASEPATH/etc/profile.d/conda.sh" # otherwise conda complains about 'shell not initialized' (needed when running in a script)
|
|
|
|
conda activate
|
|
if [ "$OS_NAME" == "osx" ]; then
|
|
echo "macOS detected. Installing MPS and CPU support."
|
|
ln -sf environments-and-requirements/environment-mac.yml environment.yml
|
|
else
|
|
if (lsmod | grep amdgpu) &>/dev/null ; then
|
|
echo "Linux system with AMD GPU driver detected. Installing ROCm and CPU support"
|
|
ln -sf environments-and-requirements/environment-lin-amd.yml environment.yml
|
|
else
|
|
echo "Linux system detected. Installing CUDA and CPU support."
|
|
ln -sf environments-and-requirements/environment-lin-cuda.yml environment.yml
|
|
fi
|
|
fi
|
|
conda env update
|
|
|
|
status=$?
|
|
|
|
if test $status -ne 0
|
|
then
|
|
echo "Something went wrong while installing Python libraries and cannot continue."
|
|
echo "See https://invoke-ai.github.io/InvokeAI/INSTALL_SOURCE#troubleshooting for troubleshooting"
|
|
echo "tips, or visit https://invoke-ai.github.io/InvokeAI/#installation for alternative"
|
|
echo "installation methods"
|
|
else
|
|
ln -sf ./source_installer/invoke.sh.in ./invoke.sh
|
|
ln -sf ./source_installer/update.sh.in ./update.sh
|
|
|
|
conda activate invokeai
|
|
# configure
|
|
echo "Calling the configure_invokeai script"
|
|
python scripts/configure_invokeai.py
|
|
status=$?
|
|
if test $status -ne 0
|
|
then
|
|
echo "The configure_invoke.py script crashed or was cancelled."
|
|
echo "InvokeAI is not ready to run. Try again by running"
|
|
echo "update.sh in this directory."
|
|
else
|
|
# tell the user their next steps
|
|
echo "You can now start generating images by running invoke.sh (inside this folder), using ./invoke.sh"
|
|
fi
|
|
fi
|
|
|
|
conda activate invokeai
|