通过Serverless私有化部署ChatGPT Web
作为开发人员,想要自己部署一个渠道访问或是想随时访问但是奈何魔法有限,又或是海外服务器太贵,不想耗费这个钱,本文借助 Serverless 来搭建一下私有 ChatGPT 服务,Serverless 按照使用量来计费,个人使用下(满足工作和生活)费用相当低。
本文过程较为繁琐,也有更为简便的其他方式:
https://rptzik3toh.feishu.cn/docx/XtrdduHwXoSCGIxeFLlcEPsdn8b
前言
本次搭建过程需要满足以下几个条件,需要预先满足,已经注册或是从一些渠道获取到了 Api key,有自己的备案域名。
- 已有 Api key
- 需要开通阿里云 Serverless
- 需要开通阿里云容器镜像服务
- 已有备案域名

云函数
开通服务(略过,免费开通), https://www.aliyun.com/product/fc
- 顶部选择地域,如硅谷
- 左侧选择服务及函数
- 创建服务,填写服务描述信息即可

容器镜像服务
开通服务(掠过,免费开通), https://www.aliyun.com/product/acr
- 顶部选择海外站点,如硅谷

- 进入个人实例。创建镜像仓库,下一步中选择本地仓库,保存。

- 点击仓库名称进入仓库内部,该部分命令稍后会用到,此处只需看到即可。

ChatGPTVNextWeb
https://github.com/Yidadaa/ChatGPT-Next-Web
该仓库实现了 ChatGPT 的交互 UI,提供了 Docker 镜像方便部署。可将该镜像上传到个人的容器镜像服务(供 Serverless 绑定部署使用)。
- 拉取 VNextWeb 镜像到本地
docker pull yidadaa/chatgpt-next-web
- 本地登录容器镜像服务(见容器镜像服务节末图)
docker login --username=用户名 registry.us-west-1.aliyuncs.com
- 标记本地 VNextWeb 镜像版本
- 查看镜像 id
docker images
eg:查看本地镜像,复制Id

- 设置镜像版本
docker tag [ImageId] registry.us-west-1.aliyuncs.com/partner/chatgptnextweb:[镜像版本号]
eg:此处直接标记最新版本 latest
docker tag a58372f00c78 registry.us-west-1.aliyuncs.com/partner/chatgptnextweb:latest
- 上传镜像到容器镜像服务
docker push registry.us-west-1.aliyuncs.com/partner/chatgptnextweb:[镜像版本号]
eg:推送镜像
docker push registry.us-west-1.aliyuncs.com/partner/chatgptnextweb:latest
创建函数
回到 Serverless 管理页面中,开始创建函数

基础设置
使用镜像创建方式,填写描述信息,选择如下设置即可。

选择镜像与端口设置
选择容器镜像服务中个人实例下镜像仓库中的镜像,仓库需要和当前 Serverless 地域相同,设置监听端口 3000。

高级设置
选择最低配置即可,该配置足矣满足个人使用。

环境变量设置
- CODE, 设置访问密码,可设置多个(逗号隔开)以方便共享给其他人使用,不设置则任何人都可访问(谨慎)。
- OPENAI_API_KEY, ChatGPT 的 Api key。

一切完毕点击创建即可。
访问函数
如上创建完毕后会跳转到详情页,点击测试函数,开始部署

如执行完毕,得到返回页面则部署成功。

私有域名
当部署完毕云服务商会提供一个生成好的域名(点击触发器管理),但不能在浏览器中访问(直接访问会下载访问页面成文件形式),需要配合自定义域名使用。

添加自定义域名
点击创建自定义域名跳转到新页面中,点击添加自定义域名跳转到添加页面。复制如下红箭头地址,进入到下一步中。

此处需要已经有了一个备案好的域名,不管是在阿里云还是腾讯云。此处以腾讯云为例,进入 dns 解析页 https://console.dnspod.cn/dns

添加记录,设置想要的域名前缀,记录类型选择 CNAME,记录值中粘贴上一步的复制的公网 CNAME 值,确认即可。
回到添加自定义域名页面,设置域名地址(域名前缀.域名主体, 例如 cn.bing.com),再选择服务名,函数名和版本,创建即可。

通过域名地址访问,则可看到页面内容,点击设置填写预先设置好的访问密码。便可使用自己的 ChatGPT 服务了。

2023-05-11,望技术有成后能回来看见自己的脚步
通过Serverless私有化部署ChatGPT Web的更多相关文章
- 快速使用ChatGpt Web Server
快速使用ChatGpt Web Server ChatGpt Web Server是使用Blazor Server模式部署的一个服务,所有的逻辑和代码执行都会在服务器执行,然后通过SignalR传输到 ...
- Spire.Cloud 私有化部署教程(二)- Ubuntu 18.04 系统
本教程主要介绍如何在Ubuntu 18.04系统上实现Spire.Cloud私有化部署.CentOS 7系统部署请参考 这篇教程. 详细步骤如下: 一.环境配置 1.关闭防火墙 1)首先查看防火墙状态 ...
- Spire.Cloud 私有化部署教程(一) - CentOS 7 系统
Spire.Cloud支持的Linux服务器系统包括CentOS和Ubuntu(推荐使用CentOS 7和Ubuntu 18版本),本教程主要介绍如何在CentOS 7系统上实现Spire.Cloud ...
- .net core 和 WPF 开发升讯威在线客服系统【私有化部署免费版】发布
希望 .net 和 WPF 技术时至今日,还能有一些存在感. 这个项目源于2015年前后,当时开发的初版,我使用了 ASP.NET MVC 做为后端,数据库使用原生 ADO.NET 进行操作.WPF ...
- 10分钟学会VS NuGet包私有化部署
前言 我们之前实现了打包发布NuGet,但是发布后的引用是公有的,谁都可以访问,显然这种方式是不可取的. 命令版本:10分钟学会Visual Studio将自己创建的类库打包到NuGet进行引用(ne ...
- Spire.Cloud 私有化部署教程(三) - Windows 系统
本教程主要介绍如何在 Windows 系统上实现 Spire.Cloud 私有化部署. 详细步骤如下: 一.安装依赖 我们的私有部署的依赖有 Nodejs.MySQL.Redis 和 RabbitMQ ...
- GitLab私有化部署 - CI/CD - 持续集成/交付/部署 - 源代码托管 & 自动化部署
预期目标 源代码管理 借助GitLab实现源代码托管,私有化部署版本,创建项目,创建用户组,分配权限,项目的签入/牵出等. 自动化部署 源代码产生变更时(如签入),自动化编译并发布到指定服务器中部署, ...
- 基于开源的 ChatGPT Web UI 项目,快速构建属于自己的 ChatGPT 站点
作为一个技术博主,了不起比较喜欢各种折腾,之前给大家介绍过 ChatGPT 接入微信,钉钉和知识星球(如果没看过的可以翻翻前面的文章),最近再看开源项目的时候,发现了一个 ChatGPT Web UI ...
- Eclipse部署Maven web项目到tomcat服务器时,没有将lib下的jar复制过去的解决办法
我们在做web开发是,经常都要在eclipse中搭建web服务器,并将开发中的web项目部署到web服务器进行调试,在此,我选择的是tomcat服务器.之前部署web项目到tomcat进行启动调试都很 ...
- 阿里云部署Java web项目初体验(转)
林炳文Evankaka原创作品.转载请注明出处http://blog.csdn.net/evankaka 摘要:本文主要讲了如何在阿里云上安装JDK.Tomcat以及其配置过程.最后以一个实例来演示在 ...
随机推荐
- VC9.0 for Python2
python2安转包时提示: pip install xxx时,提示 Microsoft Visual C++ 9.0 is required 下载并安装: 链接:https://pan.baidu. ...
- 大量数据的mysql分页查询
优化之前 SELECT a, b FROM c LIMIT 800000,5000 优化之后 SELECT a, b FROM c WHERE id >= ( SELECT id FROM c ...
- Java笔记第十三弹
函数式接口 有且仅有一个抽象方法的接口 适用于Lambda使用的接口 @FunctionalInterface//表示函数式接口 函数式接口作为方法的参数 public class Main{ pub ...
- 后疫情时代,RTE“沉浸式”体验还能这么玩?丨RTE 2022 编程挑战赛赛后专访
前言 9 月 17 日,由声网.环信与 RTE 开发者社区联合主办的"RTE 2022 编程挑战赛"圆满落幕.从 300+ 支参赛队伍中冲出重围的 27 支决赛队伍,在元宇宙中用精 ...
- P6666 [清华集训2016] 数据交互 题解
## P6666 [清华集训2016] 数据交互 题解 ### 简要题意: n个点的树,m次操作,分别为添加一条路径$(u_i,v_i,w_i)$,和撤消一条路径,每一次操作后求出一条路径使得与这条路 ...
- InnoDB 索引深入剖析
InnoDB页 将数据划分为若干个页(page),以页作为磁盘和内存之间交互的基本单位,InnoDB中页的大小一般为 16KB.也就是在一般情况下,一次最少从磁盘中读取16KB的内容到内存中,一次最少 ...
- H5 visibilityChange事件 --- 监听页面的显示或者隐藏 新开一个webview
mounted() { document.addEventListener('visibilityChange', 事件处理函数) }, destoryed() { document.removeEv ...
- DevOps 在未来将如何演进?丨行业观察
自2007年 DevOps 这一概念推出以来,越来越多企业开始将开发和运维团队结合在一起,以加快部署速度,提高软件开发生命周期的效率和协作.但是,诸多因素都会对 DevOps 是否成功产生影响,例如组 ...
- ES6let const
let const class 类 import 引入模块 export 暴露接口 // var a = 10; // let b = 20; // const c = 30; var和let比 co ...
- 经GitHub将kubernetes镜像推送到阿里云
背景 在安装kubernetes时会出现无法访问镜像站的情况,通过GitHub将kubernetes镜像推送到阿里云之后,即可使用阿里云地址引用所需镜像,现已同步镜像5000+,当前还在陆续同步.仓库 ...