如何在Linux服务器上安装Stable Diffusion WebUI

2024-05-01 16:12

本文主要是介绍如何在Linux服务器上安装Stable Diffusion WebUI,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

如何在Linux服务器上安装Stable Diffusion WebUI

  • 一、前提条件
    • 1、硬件条件
    • 2、软件条件
  • 二、安装步骤
    • 1、创建Python虚拟环境
    • 2、安装必要的软件和库
    • 3、克隆Stable Diffusion WebUI仓库
    • 4、安装依赖
    • 5、运行
    • 6、访问WEB UI

一、前提条件

1、硬件条件

GPU:显存肯定越大越好,8G以上显存,建议16G以上,24g玩的好,32g可以开目前的最大。

内存:16G以上,建议32G,也是越大越好。

硬盘:使用固态硬盘,剩余空间200G以上。

2、软件条件

最好提前装好anaconda、Git、wget这些工具。
既然已经可以自己部署Stable Diffusion的地步了,服务器上最起码的环境已经搭建好了。

二、安装步骤

1、创建Python虚拟环境

我目前部署的是v1.9.3版本的Stable Diffusion,需要3.10.6版本的Python,最好按照官方的指示操作,我的anaconda的版本是3.7,在后续安装requirements.txt时会发生好多包无法安装的问题,所以可以在安装anaconda时就用3.10版本的,或者直接像下边在创建环境时指定。

# 创建环境
conda create -n sd python=3.10.6
#激活环境
conda activate sd

2、安装必要的软件和库

在服务器上安装必要的工具

sudo apt install wget git python3 python3-venv libgl1 libglib2.0-0

可以自行查看自己的服务器上已经安装了哪些,如果已经安装了就可以不装。比如已经安装了anaconda,那么python3,python3-venv就可以不需要安装了。

如果非root用户,也是可以安装上述工具的,只是需要一点额外的操作,具体看:

https://blog.csdn.net/xfysq_/article/details/138339868?spm=1001.2014.3001.5501

3、克隆Stable Diffusion WebUI仓库

使用 Git 克隆 AUTOMATIC1111 的 stable-diffusion-webui 仓库:
在服务器中进入你想要放置拉取的仓库的目录,

git clone https://github.com/AUTOMATIC1111/stable-diffusion-webui.git
cd stable-diffusion-webui

4、安装依赖

有的教程会让你这两个依赖文件都安装一遍,其实这两个依赖文件是一样的,只不过requirements_versions.txt严格限制了版本,requirements.txt对版本要求比较宽松,我也是都安装了一遍。

pip install -r requirements_versions.txt
pip install -r requirements.txt

在这里如果没有科学上网,那建议大家一定要换源,否则会特别慢,可以参考:

https://blog.csdn.net/xfysq_/article/details/107090640

在安装依赖时,发现了一个问题,我在服务器上的个人账号目录下安装的是cuda11.3,但是Stable Diffusion安装依赖时却会安装12.1版本的cuda,而且最终Stable Diffusion也可以正常运行,这是因为cuda11.3算是你的系统cuda版本,而Python 包(如 PyTorch、TensorFlow 等)通常以预编译的形式提供,其中可能包含了特定版本的 CUDA 库。当使用 pip 安装这些包时,它们会包含与该版本捆绑的 CUDA 版本,这与在系统上安装的 CUDA 版本无关。

5、运行

一旦所有依赖项安装完毕,就可以启动 Web UI:

python launch.py

./webui.sh

都可以。

但在运行时,由于之前换过源,不是从anaconda的官方下载的包,所以可能在这又会重新安装一遍依赖,并且由于是从官方源下载,会特别慢,像卡住了一样。

因为这里是在脚本内部,无法像pip安装那样换源,因此,最好在这里提前将pip源永久换为其他源。也可以参考:

https://blog.csdn.net/xfysq_/article/details/107090640

在这里通常会遇到的两个问题:

(1)下载Downloading: "https://huggingface.co/runwayml/stable-diffusion-v1-5/resolve/main/v1-5-pruned-emaonly.safetensors"模型时,由于huggingface目前国内限制直接访问,因此模型无法下载,这是可以自己在本地利用科学上网下载之后,上传到/stable-diffusion-webui/models/Stable-diffusion/目录中。

(2)有了模型之后,仍然会提示OSError: Can’t load tokenizer for ‘openai/clip-vit-large-patch14’.问题,这也是因为huggingface目前国内限制直接访问,因此模型无法下载,可以到https://huggingface.co/models这个网站下载好openai/clip-vit-large-patch14之后,放到/stable-diffusion-webui/目录下,这也是openai/clip-vit-large-patch14的默认目录,不需要到/stable-diffusion-web ui/repositories/stable-diffusion-stability-ai/ldm/modules/encoders/modules.py里去修改openai/clip-vit-large-patch14的加载路径。

6、访问WEB UI

打开Web浏览器,输入http://127.0.0.1:7860来访问Web UI。

因为是在服务器上部署的,所以有很大可能你在本地浏览器输入上述网址是打不开的,这里需要配置 SSH 隧道,可以参考:

https://blog.csdn.net/xfysq_/article/details/138340373?spm=1001.2014.3001.5501

然后你就可以使用啦。

这篇关于如何在Linux服务器上安装Stable Diffusion WebUI的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/952110

相关文章

linux-基础知识3

打包和压缩 zip 安装zip软件包 yum -y install zip unzip 压缩打包命令: zip -q -r -d -u 压缩包文件名 目录和文件名列表 -q:不显示命令执行过程-r:递归处理,打包各级子目录和文件-u:把文件增加/替换到压缩包中-d:从压缩包中删除指定的文件 解压:unzip 压缩包名 打包文件 把压缩包从服务器下载到本地 把压缩包上传到服务器(zip

Linux 网络编程 --- 应用层

一、自定义协议和序列化反序列化 代码: 序列化反序列化实现网络版本计算器 二、HTTP协议 1、谈两个简单的预备知识 https://www.baidu.com/ --- 域名 --- 域名解析 --- IP地址 http的端口号为80端口,https的端口号为443 url为统一资源定位符。CSDNhttps://mp.csdn.net/mp_blog/creation/editor

【Python编程】Linux创建虚拟环境并配置与notebook相连接

1.创建 使用 venv 创建虚拟环境。例如,在当前目录下创建一个名为 myenv 的虚拟环境: python3 -m venv myenv 2.激活 激活虚拟环境使其成为当前终端会话的活动环境。运行: source myenv/bin/activate 3.与notebook连接 在虚拟环境中,使用 pip 安装 Jupyter 和 ipykernel: pip instal

Retrieval-based-Voice-Conversion-WebUI模型构建指南

一、模型介绍 Retrieval-based-Voice-Conversion-WebUI(简称 RVC)模型是一个基于 VITS(Variational Inference with adversarial learning for end-to-end Text-to-Speech)的简单易用的语音转换框架。 具有以下特点 简单易用:RVC 模型通过简单易用的网页界面,使得用户无需深入了

Linux_kernel驱动开发11

一、改回nfs方式挂载根文件系统         在产品将要上线之前,需要制作不同类型格式的根文件系统         在产品研发阶段,我们还是需要使用nfs的方式挂载根文件系统         优点:可以直接在上位机中修改文件系统内容,延长EMMC的寿命         【1】重启上位机nfs服务         sudo service nfs-kernel-server resta

【Linux 从基础到进阶】Ansible自动化运维工具使用

Ansible自动化运维工具使用 Ansible 是一款开源的自动化运维工具,采用无代理架构(agentless),基于 SSH 连接进行管理,具有简单易用、灵活强大、可扩展性高等特点。它广泛用于服务器管理、应用部署、配置管理等任务。本文将介绍 Ansible 的安装、基本使用方法及一些实际运维场景中的应用,旨在帮助运维人员快速上手并熟练运用 Ansible。 1. Ansible的核心概念

Linux服务器Java启动脚本

Linux服务器Java启动脚本 1、初版2、优化版本3、常用脚本仓库 本文章介绍了如何在Linux服务器上执行Java并启动jar包, 通常我们会使用nohup直接启动,但是还是需要手动停止然后再次启动, 那如何更优雅的在服务器上启动jar包呢,让我们一起探讨一下吧。 1、初版 第一个版本是常用的做法,直接使用nohup后台启动jar包, 并将日志输出到当前文件夹n

[Linux]:进程(下)

✨✨ 欢迎大家来到贝蒂大讲堂✨✨ 🎈🎈养成好习惯,先赞后看哦~🎈🎈 所属专栏:Linux学习 贝蒂的主页:Betty’s blog 1. 进程终止 1.1 进程退出的场景 进程退出只有以下三种情况: 代码运行完毕,结果正确。代码运行完毕,结果不正确。代码异常终止(进程崩溃)。 1.2 进程退出码 在编程中,我们通常认为main函数是代码的入口,但实际上它只是用户级

【Linux】应用层http协议

一、HTTP协议 1.1 简要介绍一下HTTP        我们在网络的应用层中可以自己定义协议,但是,已经有大佬定义了一些现成的,非常好用的应用层协议,供我们直接使用,HTTP(超文本传输协议)就是其中之一。        在互联网世界中,HTTP(超文本传输协议)是一个至关重要的协议,他定义了客户端(如浏览器)与服务器之间如何进行通信,以交换或者传输超文本(比如HTML文档)。