最近看Stable Diffusion开源了,据说比Disco Diffusion更快,于是从git上拉取了项目尝试本地部署了,记录分享一下过程~这里是官网介绍:https://stability.ai/blog/stable-diffusion-public-release
2.必要前提:- 科学上网。很多链接都需要用到。显卡的显存需要足够大,至于多大没看到哪有说,反正6g绝对不行
3.1 Anaconda安装
这是一个运行python的环境管理工具
进入 Anaconda官网,https://www.anaconda.com/
点击Download下载,打开文件一路next到这个界面,勾上第一项,把该命令注册到环境变量
点击install开始下载,下载完成后,点击右下角开始界面,可在最近添加里看到 Anaconda Prompt,建议右键更多以管理员身份运行。
3.2 Anaconda配置
后续需要生成环境,下载python包,但网络很不好,建议替换源
在刚才打开的 Anaconda Prompt 窗口输入以下命令进行全局配置
pip config set global.index-url https://pypi.tuna.tsinghua.edu.cn/simple
打开此电脑,进入 C:\Users\<你的用户名> 这个路径,可以看到.condarc文件
打开它,我这里用的是Notepad++,应该用记事本也行,复制以下内容进去,保存
default_channels:
- https://mirrors.tuna.tsinghua.edu.cn/anaconda/pkgs/main
- https://mirrors.tuna.tsinghua.edu.cn/anaconda/pkgs/r
- https://mirrors.tuna.tsinghua.edu.cn/anaconda/pkgs/msys2
custom_channels:
conda-forge: https://mirrors.tuna.tsinghua.edu.cn/anaconda/cloud
msys2: https://mirrors.tuna.tsinghua.edu.cn/anaconda/cloud
bioconda: https://mirrors.tuna.tsinghua.edu.cn/anaconda/cloud
menpo: https://mirrors.tuna.tsinghua.edu.cn/anaconda/cloud
pytorch: https://mirrors.tuna.tsinghua.edu.cn/anaconda/cloud
pytorch-lts: https://mirrors.tuna.tsinghua.edu.cn/anaconda/cloud
simpleitk: https://mirrors.tuna.tsinghua.edu.cn/anaconda/cloud
show_channel_urls: true
ssl_verify: false
3.3 git安装
进入git下载链接,https://git-scm.com/downloads
点击Download for Windows,下载完打开一路默认,安装完成
(这里之所以把git放到后面安装,是因为我在Prompt里碰到没有git命令的问题,重装解决)
4.开始部署:4.1 下载Stable Diffusion项目
在刚才打开的Anaconda Prompt窗口里,进入到你想要进入的目录
刚进来的目录是C:\Windows\system32,比如我这里想要放置目录是D:\git_pro,则输入以下命令(注意>之后的才是输入的内容)
(base) C:\Windows\system32>cd ../..
(base) C:\>D:
(base) D:\>cd git_pro
(base) D:\git_pro>git clone https://github.com/CompVis/stable-diffusion.git
git clone很卡的话,访问 https://github.com/CompVis/stable-diffusion,点击绿色按钮code再点击Download ZIP,解压到该目录下也行
4.2 安装Stable Diffusion环境
这里是重点,源不好的话经常会卡住
进入到项目目录下,按README.md的指引操作
(base) D:\git_pro>cd stable-diffusion-main
(base) D:\git_pro\stable-diffusion-main>conda env create -f environment.yaml
这里要下载不少时间,可能会报错,通常是源太卡了
也可能是git太卡,因为该过程还需要在项目的src目录下clone两个其他项目下来(见 environment.yaml,不要想把他们直接下载放到该目录,后面运行会报错)
4.3 下载模型
安装好环境后,还不能进入使用,因为需要的模型还没有下载
模型有几种,需要去 https://huggingface.co/CompVis 下载,这里还需要注册账号,先注册下
如果我们用sd-v1-4.ckpt这个模型,就在该网页里点击stable-diffusion-v-1-4-original那一项
跳转过去,找到Download the weights下面的sd-v1-4.ckpt即可点击下载,通常几G,下载时间较长。
4.4 设置模型文件路径
见Stable Diffusion项目README.md的这一步,是要我们把模型的路径软链过去,但我想大家Windows电脑应该没有这个命令吧
简便一点,我们下载好模型以后,找个地方存起来
打开资源管理器,去 D:\git_pro\stable-diffusion-main\models\ldm 路径新建stable-diffusion-v1文件夹,然后把模型文件复制过来,再把模型名字改成model.ckpt
我这里把下载的模型都新建一个文件夹models放到里面,方便复制替换
4.5 运行
终于来到这一步了,前面所做的一切都是为了这一步啊!!
刚才在Anaconda Prompt窗口输入conda env create那一步,我们新建了环境ldm,现在切换过去,在Anaconda Prompt窗口输入以下命令
(base) D:\git_pro\stable-diffusion-main>conda activate ldm
当然官方建议我们可以更新一下pytorch包,应该是可不跑的,贴一下
conda install pytorch torchvision -c pytorch
pip install transformers==4.19.2 diffusers invisible-watermark
pip install -e .
最后!!就是我们的跑图命令了
(ldm) D:\git_pro\stable-diffusion-main>python scripts/txt2img.py --prompt "a photograph of an astronaut riding a horse" --plms
--prompt后面的就是你的描述,可输入python scripts/txt2img.py --help查看各种参数配置
接下来就是见证奇迹的时刻~
诶,等会儿,这是啥?
一口老血吐出来,显存不够,所以说必要前提还是要注意的,白忙了
只能等我换了显卡再说咯,留给3090ti的朋友去试试~
5.QA:5.1 不想部署,只想玩玩?
其实想玩玩,也可以去网站:https://huggingface.co/spaces/stabilityai/stable-diffusion 这个要稍微排队一下
https://beta.dreamstudio.ai/dream 这个DreamStudio测试版要注册,支持一些参数,不用排队
5.2 生成了错误环境
可能你乱改environment.yaml文件,生成了错误的环境,此时需要把yaml重新恢复,不用删除该环境,可以运行update命令更新,如下
conda env update -f environment.yaml
5.3 报错 'git' is not recognized as an internal or external command, operable program or batch file.
这是没有git命令,之前安装过git的,Anaconda Prompt窗口也可能没有加载到git
解决方法,重装git
5.4 第二次运行,报错 ModuleNotFoundError: No module named 'CV2'
因为你的程序依赖包都在新建的安装环境ldm下,所以每次重新打开Anaconda Prompt都需要再切一次环境,再跑你的程序,切环境命令如下:
conda activate ldm
5.5 每次进入项目目录好麻烦
可以直接在项目资源管理器输入cmd并回车,进入命令行工具
5.6 如何设置参考图
有参考图的配置是另一个命令,如下,
python scripts/img2img.py --prompt "A fantasy landscape, trending on artstation" --init-img <path-to-img.jpg> --strength 0.8
5.7 显存不够,按照提示设置max_split_size_mb变量行不行?
本来我以为max_split_size_mb的单位是g,设置以后报错,我还狠狠吐槽了一下
结果吐槽完才反应过来单位应该是mb,满怀期待又去设置了一下,还是老样子的报错,硬件是硬伤,不过有想试试的也可参考流程:
左下角搜“环境变量”,点进去
按此123操作,变量名PYTORCH_CUDA_ALLOC_CONF,变量值max_split_size_mb:xxx
暂时想不到其他坑了,有误请指正~~