手把手教你在云环境炼丹(部署Stable Diffusion WebUI)

news2025/1/2 22:41:23

前几天写了一篇《手把手教你在本机安装Stable Diffusion秋叶整合包》的文章,有些同学反映对硬件的要求太高,显卡太TM贵了。今天我再分享一个云服务器炼丹的方法,方便大家快速入门上手,这个云服务不需要特殊网络设置,能连接公网网盘,随开随用,有3090显卡,也有4090显卡,不过我经常使用的是A5000显卡。本文非广告推广,只分享使用方法,不喜跳过。

闲话不多说,下面就正式开始了。

注册登陆

注册方式一

手机号直接注册,打开这个链接:www.autodl.com/register,很简单就不多说了。

注册方式二

为什么还有两种方式?测试的时候发现验证码发不出去,官方说这两天验证码通道有点问题,有时发不出去。具体原因就不知道了,做个备选吧。

在它的登陆页面,点击“微信登陆”按钮,用微信扫一扫,在微信打开的页面中,点击“关注公众号”,关注成功后,AutoDL的网页会自动跳转,要求绑定手机号,这个验证码却能收到,感觉有点奇怪。

开服务器

注册成功之后,就可以登录了,登陆成功之后会进入一个管理界面。

之前听说注册用户还送10块钱,现在应该没有了,现在是会送30天的炼丹会员,单价上有些折扣,正常情况下这个折扣需要消费达到500元才会有。

没有钱就开不了服务器,所以我们要先充点钱进去。

充值

鼠标划到管理界面右上角的这个账户名称上,在弹出的窗口中点击“充值”。

在“充值”页面中,选择“其它金额”,我这里充值5块,你可以试试更小的金额能不能开机。每次少冲点也可以避免忘了关机导致被扣钱心疼的问题。

付款方式按照自己的情况选择就行了,具体支付流程大家都应该很熟练了,这里就不演示了。

租用实例

在管理界面的右上角点击“控制台”。

然后在左侧菜单中点击“容器实例”,在打开的页面中点击“租用新实例”。

在“创建实例”的页面,按照下图的顺序设置。

  • 计费方式:一开始体验选择“按量计费”就可以了。
  • 选择地区:大家都推荐内蒙A区,据说网络比较稳定,我也一直用这个。
  • GPU型号:A5000每小时 1.18,实测性能也可以。
  • GPU数量:先选择1个,后边熟练了再根据实际情况来。
  • 选择主机:GPU型号和数量选择后,这里就会列出可用的主机,先随便选一个就行了。

下边还有一些设置。

数据盘:的免费容量是50G,如果不够需要花钱扩容,一般50G也够了。

镜像:首先选择“社区镜像”,然后在输入框中输入“yinghuoai”,会自动弹出一个镜像,选中它就行了。这个镜像是我专门修改过的,后续也会不断优化升级,大家有问题向我反馈就行。当然也可以用别的镜像,不过后边启动SD WebUI的步骤可能有些不同,建议先按照我这个步骤跑一遍再说。

最后点击“立即创建”。

启动

现在服务器实例已经启动起来了,我们还需要2步来启动 Stable Diffusion WebUI。

本机启动

点击“快捷工具”这一列中的“JupyterLab”,如下图所示:

上边的操作会在浏览器中打开一个新的页面,JupyterLab的页面。JupyterLab 是一个Web应用程序,可以管理文件、记点东西、运行程序,功能类似于VSCode。

参照下图,执行以下2个步骤:

  • 在页面左侧的文件管理器中双击“启动器.ipynb”;
  • 在页面右侧打开的页签中点击红框中的启动按钮。

首次启动要下载一些模型,会有点慢,大概2-3分钟。后边再启动就会跳过这些下载步骤,达到秒级。

看到下图的“Running on local URL”和“Model loaded in” 就说明启动成功了。

其中的“http://127.0.0.1:6006”就是SD WebUI的访问地址,不过这个地址只能本机访问,而这个云服务器本质上只是个容器实例,没有桌面环境,也没有浏览器可以用。当然这个问题可以解决,请继续看下文。

映射到外网

回到容器实例列表,找到刚才启动的实例,在“快捷工具”中点击“自定义服务”,如下图所示:

如果第一次使用自定义服务,它会弹出一个身份认证的提示。因为AutoDL会把SD WebUI的本机访问地址映射到外网,大家可能都听说过网站备案这件事,这里AutoDL给大家提供的外网地址用的是AutoDL自己备案过的域名的子域名,所以AutoDL要承担一定的风险,出了问题的时候它得能找到人,所以需要身份认证。

按照提示操作就行了,这里我使用个人认证进行演示。

输入姓名和身份证号,注意一个身份证只能在AutoDL上认证一次,多个账号就得用不同的身份证号来认证。

只要姓名和身份证号能对上,上边的认证就通过了。

我们再次点击“自定义服务”,这时候会弹出一个警告,意思就是不要乱搞,乱搞必被罚。我们都是好人,勾选同意服务协议,然后点击“访问”。

然后AutoDL就会在浏览器中打开一个新的页签,稍等片刻,期待已久的 SD WebUI 页面就展示出来了。

出图

为了方便大家绘画,这个镜像自带两个大模型,一个二次元,一个真实视觉。

这里以二次元模型为例,演示如何生成图片。

1、选择大模型,这里是默认的二次元模型 AnythingV5。

2、提示词,先来个简单的:a girl。

3、反向提示词:EasyNegative,这是一个嵌入式模型的代号,揉合了一些常见的反向提示词。

4、点击生成。

5、稍等片刻,图片就生成出来了,可以点击放大,右键保存。

更多的参数和设置,后续会有其它文章介绍,请及时关注公/众\号:萤火遛AI(yinghuo6ai)。

这里还有一些云服务器的使用问题需要关注,请继续看下文。

关机/开机

本文介绍的服务器实例计费方式是按量付费,每小时计费1次,如果暂时不用了,记得“关机”。

建议使用“小程序管理实例”,当你记不清楚的时候,就打开微信小程序看看,避免白白的浪费资源。

关机之后再次开机可能会遇到GPU无法分配的问题,因为服务器都是共享的,你关机的时候,别人就可能继续使用这个服务器的计算资源,再次开机时可能就没有足够的显卡了。

这时候怎么办?别慌,有办法。

在关机实例的“更多”这里,点击“克隆实例”,

在弹出的提示中,有两个关键的信息:1、数据盘不会自动拷贝,需要手动处理 2、每天3次克隆机会。

点击“确定”之后的流程和创建新服务器差不多,只不过不需要选择容器镜像了。

然后就可以在容器实例列表中看到克隆的进度:

新实例启动后,如果还需要数据盘的数据,我们需要在原实例的“更多”中点击“跨实例拷贝数据”:

在弹出的窗口中,选择“目标实例”,也就是克隆出的新实例;“源实例数据路径”填写:*,代表数据盘所有的文件。

等待数据拷贝完成:

数据拷贝完毕后,就可以使用新的实例继续工作了。

启动 SD WebUI 的方法在上边的步骤中介绍过了,这里就不重复了。

存储

文件管理

JupyterLab自带一个文件管理器。

  • 点击右上角的文件夹图标可以开启/关闭文件管理器
  • 这个文件管理器的根目录实际对应的是Linux系统的 /root 目录。
  • 鼠标双击文件后会在右侧的编辑器中打开。

对文件夹和文件的操作可以通过鼠标右键触发,可以看到这里边有很多操作,新建、复制、删除都有了,还是挺方便的。

对于服务器和本地文件的交互,我们可以通过这个文件管理器的上传、下载实现。

公网网盘

AutoDL系统盘是30G、数据盘是50G,如果超出就需要付费购买数据空间。虽然我们已经将各种模型搬到了数据盘中,但是大模型动辄就2-5G,所以免费的数据盘也放不下几个模型,而且我们还有各种插件和生成的文件。

考虑下使用场景,对于模型,我们不会同时使用所有模型,所以可以把它们先放到别的地方,用的时候再加载进来,不怎么用的就挪到别的地方。这个别的地方可以是用户本地电脑,但是也会占用很多空间,所以很多时候就是各种网盘,比如百度网盘、阿里云盘这种。AutoDL支持的“公网网盘”就是干这件事的。

网盘授权

在实例列表中,找到需要下载数据的实例,点击“AutoPanel”:

在AutoPanel页面中点击“公网网盘”,这里需要设置一个密码。

设置密码之后,就可以进行网盘授权了,阿里云盘不怎么限速,所以建议优先使用它。没有阿里云盘的同学需要先去注册个账号,然后手机上安装它的APP,扫码授权。

授权通过后,当前服务器就可以操作云盘了。不过这样授权之后,只有当前服务器可以访问网盘,其它服务器想要访问网盘还得重新授权。

AutoDL提供了一个方法,把授权信息保存到一个独立的位置,新开的实例自动加载授权信息。

操作方法是,在已经授权的服务器这里,点击“导出授权”。

在弹出的窗口中,点击“复制授权信息”。

然后打开AutoDL的控制台,进入“账号”->“设置”->“公网网盘”,粘贴前边复制出来的授权信息,最后点击“确定”按钮。这样新创建的实例就自动授权了,访问网盘的时候只需要输入独立密码就行了。

下载文件

在授权过的公网网盘这里,找到你要下载到本地的文件,点击“下载”按钮。

确认下载文件的位置,这里不能修改,知道就行了,点击“确定”开始下载。

下载完毕后,进入到 JupyterLab 中,进入“autodl-tmp”文件夹,可以看到我们下载的文件。

如果你需要把文件移动到别的目录,在目标文件上点击右键,在弹出的菜单中点击“剪切”。

然后通过文件管理器进入到目标路径,在空白的地方点击“粘贴”,稍等片刻,文件就移动过来了。

上传文件

在“AutoPanel”的“公网网盘”页面中,点击“上传”,会弹出一个“上传文件”的页面,页面上方可以切换路径,页面下方会展示路径下的文件列表,找到想要上传的文件,点击文件后边的“上传”。

单个文件和文件夹都可以上传,但是文件夹下超过100个文件时需要先压缩再上传。可以连续发起多个上传任务,它们会排队执行。

文件存储

这部分内容因为需要用户手动开启,然后做一些技术处理,操作门槛比较高,如果搞不懂也没关系,不影响正常使用。

AutoDL本身提供了一个名为“文件存储”的功能,可以在多个服务器实例中共享,它类似于公网网盘,但是我们能够在服务器中直接访问它,所以它比公网网盘更方便一些。

点击“初始化文件存储”之后,我们可以看到下边这个界面。可以上传、下载文件,有点可惜的是这个免费空间只有20G,如果超出20G,超出的空间会被计费,目前每G每天1分钱。

开启文件存储后,我们可以在服务器的文件系统中看到这个文件夹,挂载的就是上边创建的“文件存储”。如果服务器是“文件存储”初始化之后创建的,需要把服务器实例先关机再开机,才能成功挂载。

“文件存储”的本质是一种网络存储,它的好处是三副本存储,数据不容易丢失,但是相比服务器本地的“系统盘”和“数据盘”,访问速度会慢一些。

如果你对磁盘性能要求不高,可以把SD WebUI的部分路径改到这个下边,比如生成图片的输出路径,一些小模型等等。

更换图片输出路径的方法

(1)启动一个可以执行命令的终端。

点击 JupyterLab 中的这个加号,打开一个新的 Launcher。

在 Launcher 页面中点击“终端”。

(2)在终端执行更换路径的命令。

  • 先在“文件存储”中创建一个目录,用来保存SD生成的图片;
  • 然后把 SD WebUI 的文件输出目录删除;
  • 最后创建一个 SD WebUI 输出目录到“文件存储”中新建目录的软链接。

这样 SD WebUI 保存文件时就自动保存到了“文件存储”中。

mkdir /root/autodl-fs/webui_outputs
rm -Rf /root/stable-diffusion-webui/outputs
ln -s /root/autodl-fs/webui_outputs /root/stable-diffusion-webui/outputs

更换模型保存路径的方法

这个简单点,修改下启动命令就行了,如果使用的是 yinghuoai 的镜像,直接修改下边这个文件:

这个命令中有几个 --xxx-dir 的参数,就是各种模型的路径,按照需要替换就行。

更改完毕之后,不要忘了在 JupyterLab 中重新启动,就是点那个两个箭头的按钮。


OK,以上就是本文的主要内容了,如有问题,欢迎给我反馈。

我会经常分享一些AI方面的前沿知识和应用实例,请关注公/众\号:萤火遛AI(yinghuo6ai),以免错误精彩内容。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/816380.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【rtmp】2: rtmp 推送 annexb

参考RTMP协议封装H264和H265协议详解 大神分析rtmp推送的大部分是annexb的h264 因此,我们就以此为格式 转为rtmp avcc 推送到服务器端。 一般sps、pps 前面有4个 字节的起始码,所以要跳过,不要计算在sps pps 长度里。 对于视频,先发avc头 第一个 5个字节 第一个字节 0x17 ,…

source insight常用操作

1、窗口布局 SI窗口十分丰富,通过菜单栏View->Toolbars/panels选择显示那些工具栏/窗口 Source Insight 窗口介绍_sourceinsight窗口_STCNXPARM的博客-CSDN博客 2、RGB护眼色 Source Insight4.0字体大小及护眼背景配置_sourceinsight4背景色配置_ProYuan28的…

Let’s Encrypt 免费证书提示:(STAGING) Pretend Pear X1证书不受信任

通过Let’s Encrypt 免费申请证书,发现浏览器并不信任 原因 我使用了ACME V2 测试环境: https://acme-staging-v02.api.letsencrypt.org/directory 需要改为生产环境 https://acme-v02.api.letsencrypt.org/directory 测试环境有两个活跃的根证书…

vue中的require

vue中的require 一、基本概念二、具体演示1.引入json2.引入图片 三、require.context引入图片:引入json引入模块js:引入vue文件: 一、基本概念 require 是 node 中的一个方法,他的作用是 用于引入模块、 JSON、或本地静态文件。r…

快速开发框架若依的基础使用详解

Hi I’m Shendi 快速开发框架若依的基础使用详解 最近在为公司制作新的项目,经过了一段时间的技术沉淀,我开始尝试接触市面上用的比较多的快速开发框架,听的最多的当属若依吧 于是就选用了若依 介绍 为什么选?目的是为了提高开发…

【前端设计】尝试一文搞懂verilog parameter的全部细节

这里是尼德兰的喵芯片设计相关文章,欢迎您的访问! 如果文章对您有所帮助,期待您的点赞收藏! 让我们一起为成为芯片前端全栈工程师而努力! 一个参数的标准定义呢应该是这样的: parameter type range name …

SHELL——备份脚本

编写脚本,使用mysqldump实现分库分表备份。 1、获取分库备份的库名列表 [rootweb01 scripts]# mysql -uroot -p123456 -e "show databases;" | egrep -v "Database|information_schema|mysql|performance_schema|sys" mysql: [Warning] Using …

二十三种设计模式第十九篇--命令模式

命令模式是一种行为设计模式,它将请求封装成一个独立的对象,从而允许您以参数化的方式将客户端代码与具体实现解耦。在命令模式中,命令对象充当调用者和接收者之间的中介。这使您能够根据需要将请求排队、记录请求日志、撤销操作等。 命令模…

华为数通HCIP-IP组播基础

ospf、isis、BGP--ping通,单播路由--单播路由表; mpls--单播标签互通 点到多点业务流量下发 1、通过广播 一对所有发送; 缺陷:导致流量的有偿性、安全性得不到保障; 2、通过单播 一对一发送; 缺陷&…

嵌入式软件和硬件首先说一下怎么入门?

1,编程。这个你是否懂C语言编程,能够熟练或者熟悉使用C语言编写一段程序。不懂学习C语言。 2,单片机。你是否了解什么是单片机,单片机是做什么的。不懂的话,最好先了解一下什么是单片机,看下书&#xff0c…

万里腾飞终有路,国产替代正当时

2023年7月27-28日,I-CAR 2023 第六届细胞免疫疗法深度聚焦论坛在上海建工浦江皇冠假日酒店隆重举办,本次大会主要围绕实体瘤、质量控制&产业化、通用CAR-T疗法、免疫治疗新风口四大主题展开,就细胞免疫治疗快速发展崛起的同时&#xff0c…

openGauss学习笔记-26 openGauss 高级数据管理-约束

文章目录 openGauss学习笔记-26 openGauss 高级数据管理-约束26.1 NOT NULL约束26.2 UNIQUE约束26.3 PRIMARY KEY26.4 FOREIGN KEY26.5 CHECK约束 openGauss学习笔记-26 openGauss 高级数据管理-约束 约束子句用于声明约束,新行或者更新的行必须满足这些约束才能成…

ubuntu下,在vscode中使用platformio出现 Can not find working Python 3.6+ Interpreter的问题

有一段时间没有使用platformio了,今天突然使用的时候,发现用不了,报错: Ubuntu PlatformIO: Can not find working Python 3.6 Interpreter. Please install the latest Python 3 and restart VSCode。 上网一查,发现…

最全面的TCP、UDP、Socket、HTTP网络编程面试题

先看一天面试的经验: 第一场: 面试官:你说一下TCP的三次握手 我:第一次Client将SYN置1......、第二次Server收........、 第三次........ 面试官:很难背吧? 我:......是啊,很难&…

【编译】gcc make cmake Makefile CMakeList.txt 区别

文章目录 一 关系二 gcc2.1 编译过程2.2 编译参数2.3 静态库和动态库1 后缀名2 联系与区别 2.4 GDB 调试器1 常用命令 三 make、makefile四 cmake、cmakelist4.1 语法特性4.2 重要命令4.2 重要变量4.3 编译流程4.4 两种构建方式 五 Vscode5.0 常用快捷键5.1 界面5.2 插件5.3 .v…

程序的编译(3/13)

经过预处理后的源文件,褪去一切包装,注释被删除,预处理命令也基本上被处理掉,剩下的就是 C 代码了。接下来的第二步,就进入到编译阶段。编译阶段主要分为两步:第一步,编译器调用一系列解析工具分…

leetcode 面试题 08.05.递归乘法

⭐️ 题目描述 🌟 leetcode链接:面试题 08.05.递归乘法 思路: A 3 , B 4 ,3 * 4 等价于 3 3 3 3。 代码: int multiply(int A, int B){if (!B) {return 0;}return A multiply(A , B - 1); }

23款奔驰AMG GLE53加装原厂HUD抬头显示系统,增加您的行车安全

HUD是平视显示器的简称,它原先是运用在航空器上的飞行辅助仪器。指飞行员不需要低头,就能够看到他需要的重要资讯。由于HUD的方便性以及能够提高飞行安全,这项技术后来也发展到汽车行业。汽车搭载的HUD抬头数字显示功能,是利用光学…

Antd 日期范围选择框选择一个日期后,面板收起

需求 初始状态只有开始时间,如下图⬇️ 产品需要优化体验: 点击结束日期选择日期下拉面板直接收起,而不是需要选择起始时间 思路 需要一段逻辑的open属性控制后续操作还是由组件内部控制 逻辑 第一次打开,open控制选择了&am…

史上最全,商业智能BI干货满满

商业智能BI是什么? 商业智能BI可以实现业务流程和业务数据的规范化、流程化、标准化,打通ERP、OA、CRM等不同业务信息系统,商业智能BI整合归纳企业数据,商业智能BI利用数据可视化满足企业不同人群对数据查询、分析和探索的需求&a…