Draft: Easy Diffusion AI Setup on Linux Systems
Metadata
- Status: Proposed
- Deciders: Development Team
- Tags:
AI
,Easy Diffusion
,Linux
Backdrop
The goal is to streamline the installation process of Easy Diffusion for creating AI-generated images on Linux systems.
Challenge
The challenge lies in ensuring a simple and repeatable setup process for installing and configuring Easy Diffusion on various Linux distributions.
Strategy
- Assess compatibility between Easy Diffusion and popular Linux distributions.
- Identify dependencies and prerequisites required for Easy Diffusion.
- Develop a script or instructions for a hassle-free setup experience.
- Conduct test installations across different environments.
First, download the latest release of Easy Diffusion for Linux. Then create a dedicated user for running Easy Diffusion and establish a standard location for the tool, like /opt/easy_diffusion
.
# As root or using sudo
dnf install curl bzip2 -y
useradd --system --create-home --home-dir /opt/easy_diffusion easy_diffusion_user
mkdir -p /opt/easy_diffusion
curl -L https://github.com/cmdr2/stable-diffusion-ui/releases/latest/download/Easy-Diffusion-Linux.zip -o /opt/easy_diffusion/Easy-Diffusion-Linux.zip
unzip /opt/easy_diffusion/Easy-Diffusion-Linux.zip -d /opt/easy_diffusion/
sudo bash -c 'cat > /opt/easy_diffusion/easy-diffusion/config.yaml <<EOF
# Configuration for Easy Diffusion
# Change listen_port if port 9000 is already in use on your system.
# Set listen_to_network to true to make Easy Diffusion accessible on your local network.
net:
listen_port: 9000
listen_to_network: true
# Multi GPU setup
render_devices: auto
# Set open_browser_on_start to false to disable opening a new browser tab on each restart.
ui:
open_browser_on_start: false
# Set update_branch to main to use the stable version, or to beta to use the experimental
# beta version.
update_branch: beta
# Set force_save_path to enforce an auto save path. Clients will not be able to change or
# disable auto save when this option is set. Please adapt the path in the examples to your
# needs.
# Windows:
# force_save_path: C:\\Easy Diffusion Images\\
# Linux:
# force_save_path: /data/easy_diffusion_images/
force_save_path: /opt/easy_diffusion/easy_diffusion_images/
EOF'
chown -R easy_diffusion_user: /opt/easy_diffusion
chmod +x /opt/easy_diffusion/easy-diffusion/start.sh
A systemd service configuration is used to manage the Easy Diffusion process:
sudo bash -c 'cat > /etc/systemd/system/easy-diffusion.service <<EOF
[Unit]
Description=Easy Diffusion AI Image Generation Tool
After=network.target
[Service]
User=easy_diffusion_user
WorkingDirectory=/opt/easy_diffusion/easy-diffusion
ExecStart=/bin/bash /opt/easy_diffusion/easy-diffusion/start.sh
Restart=on-failure
[Install]
WantedBy=multi-user.target
EOF'
Enable and start the service as follows:
sudo systemctl daemon-reload
sudo systemctl enable easy-diffusion.service
sudo systemctl start easy-diffusion.service
Check the status to confirm correct operation:
sudo systemctl status easy-diffusion.service
To view detailed logs, use:
journalctl -u easy-diffusion.service
Upside
- Automates the setup process, minimizing user intervention.
- Offers consistency across different installations.
- Simplifies management with systemd integration.
Downside
- Requires thorough testing to ensure broad compatibility.
- Systemd is not universally adopted among all Linux distributions.
- Additional effort is needed to maintain the service file and update paths as necessary when new versions are released.
Further Reading
- Download for Linux: Official source code and documentation.
Aria, an AI assistant, provided support in formulating this proposal.