ChatGPT 套壳,微信小程序开源 含前后端,后端采用 quarkus,支持原生编译

2023-03-23 15:15:25 +08:00
 yangyuhan12138

PS:前端有点简陋,欢迎前端大佬来帮忙改改.

github 后端地址

github 前端地址

起因 0:

大约两周前在 v 站上看到一个 v 友做了个 GPT 套壳 然后赚了两百块,只是在心中暗暗羡慕了一下 但是也没有想自己做,重复造轮子嘛,没意思.所以就打开了 github,看看有没有大佬开源的,发现目前开源的多半是 web,或者接入微信当个聊天机器人.而我主要是想分享给亲戚朋友用用,想着还是小程序方便点.

经过 0:

在我寻找的过程中一个叫Railway的东西吸引了我,我也进去浅浅的尝试了一下,感觉很不错(可以自动将 github 上的代码打包部署,自动探测语言和打包方式)可以实现 github 上的项目一键部署.而且每个月有$5 的免费额度. 然后我就接着找,终于在 gitee 上找到个开源的 gpt 小程序套壳

于是我就把这个开源项目部署到了Railway上,深度体验了下,真的很爽,几乎 0 配置,十分的丝滑.

要是到这里就结束的话,就没有下边我要说的开源项目了.

起因 1:

由于Railway只给了$5 的免费额度,我看了下这个服务的预估消费直接就奔着$7 去了,这是要让我充钱的节奏呀,不行... 本着能白嫖就坚决不给钱的精神,我在想怎么才能让他的内存占用更低!然后我想到了个一个一年前了解过,但是没深入研究过的东西,quarkus!这个东西不就是 cloud native 的,打包成 native excutable 那内存不就下来了吗?

经过 1:

于是我就开始了接近 1.5 周的学习&实践,不得不说quarkus的性能是真的好,但是写起来也真的坑呀,国内几乎没有文档可查,直接去官网找文档; 最开始我想全部使用 reactive 的形式来写后端,但是失败了,原因是quarkus的某些组件还并不支持 reactive 的方式(比如 http basic auth),我肯定是不想写个复杂的身份校验逻辑的,但是 http auth 又不支持 reactive,没办法,要么 reactive 要么 http auth,我最终选择了后者,所以现在项目中既有 reactive 也有 imperative 的代码.

quarkus 使用心得:

所以最后我相当于研究了下 Quarkus&Railway,并以这个开源项目的形式展示出来,和大家一起交流下,当然如果对项目有兴趣的,可以直接把项目拿去用,个人只需要准备好

下面是小程序的体验码:

再贴下内存消耗的对比图:

quarkus 的

springboot 的

大家可以看到内存直接下降了 500m 500m 什么概念,500m 的意思就是我可以白嫖了,如果还不行,我打算把 mysql 干掉,现在大多数内存都是 mysql 用的...

还有个很爽的地方!众所周知,编译成原生可执行文件非常吃电脑性能,我的是 m1 的 air 编译的时候我基本上啥都干不了,而且大概编译时间会持续 10-20 分钟不等,但是如果我们使用了 Railway 我们可以把编译这个动作交给 Railway 来做,不需要你本地编译,让 Railway 编译,而且编译是不算钱的!!!!这点真的很良心,而且 Railway 编译机器的性能真的很好,我测试的时候基本上在 5 分钟左右就编译好了!

下面放个启动时间让大家爽一下:

[io.quarkus] (main) chatbot 1.0-SNAPSHOT native (powered by Quarkus 2.16.4.Final) started in 0.198s

这次启动的时间是包含了 flyway 执行 sql 脚本的时间的,要是没有 flyway 的话直接就是 0.0 几秒!

4908 次点击
所在节点    程序员
46 条回复
yangyuhan12138
2023-03-23 15:20:40 +08:00
由于 Railway 的 bug,创建的模版有问题,导致一键部署了之后还得修改一下服务的变量,直接把 Readme 里的变量贴过去就行了,选 Row editor.

真正理想的状态其实是点击一键部署之后,只需要填写一个 wx appid 和 wx secret 就行了,但是...没办法,出 bug 了 他们也正在修,不知道啥时候修好,修好了我再去优化一下
wooke
2023-03-23 15:31:03 +08:00
个人不是不能上架这种问答类的小程序吗?
yangyuhan12138
2023-03-23 15:31:52 +08:00
@wooke 可以呀..我就是才申请的 通过了.没有限制
googlefans
2023-03-23 15:48:42 +08:00
asen001
2023-03-23 15:55:37 +08:00
Railway 是不是每个月只能用 500 个小时
yangyuhan12138
2023-03-23 15:59:49 +08:00
@asen001 对针对免费计划 是一个月只能用 500 个小时 你可以一次性充$5 ,或者开通 developer 计划取消这个限制,
开通 developer 计划不会用钱,反正是按量付费如果你那个月用超了才会扣你钱,所以我们只要保证每个月实际消耗不超过$5 就可以一直白嫖,相当于开通了 developer 计划只是为了取消 500 小时限制.
dulred
2023-03-23 16:32:44 +08:00
summersun2021
2023-03-23 16:47:25 +08:00
参观一下,支持
fairytale110
2023-03-23 16:53:14 +08:00
markdown 支持不到位,头像占太多屏幕了,可以略去,滚动回复时,界面没有即时直达底部,很厉害了👍
yangyuhan12138
2023-03-23 17:01:07 +08:00
@fairytale110 界面是别人开源 我拿过来改的...我是后端...对前端一窍不通,js 还行 css 就完全不了解了
amon
2023-03-23 17:01:29 +08:00
支持!方便分享一下服务器部署这块吗?
据我有限的知识,小程序似乎不能绑定国外的服务器,那国内如何访问 openai 呢。
yangyuhan12138
2023-03-23 17:02:30 +08:00
@amon 小程序只看你域名,你域名需要再国内备过案的才行,服务器是哪的无所谓
yangyuhan12138
2023-03-23 17:04:23 +08:00
@amon 你可以试试点击 ReadMe 里边的 Deploy on Railway 一键部署(目前还需要把变量考过去替换一下,Railway 模版的 bug),然后他还会给你个临时的域名供你测试,这个时候就可以在开发者工具里边玩玩了
yangyuhan12138
2023-03-23 17:05:30 +08:00
@amon Railway 的服务器就是国外的呀..我现在就部署在上面呢 他可以直接访问 openai 所以也不想要设置什么..
amon
2023-03-23 17:09:48 +08:00
@yangyuhan12138 谢谢。如果我选择自己开发部署的话,能直接购买一台云厂商的国外主机,然后国内访问这台主机上的后台服务吗?(不清楚是否会被屏蔽和速度如何)
404www
2023-03-23 17:15:45 +08:00
很好,我愿意走你的 aff ,但是,为什么要绑卡😂
yangyuhan12138
2023-03-23 17:17:05 +08:00
@404www 不绑会有 500 小时的 limit,相当于一个月只能用 20 多天,绑了如果使用量不超也不会扣钱
yangyuhan12138
2023-03-23 17:17:56 +08:00
@amon 可以,只要域名是中国备案的
yangyuhan12138
2023-03-23 17:24:48 +08:00
@404www 而且绑了我也不会收到钱...你要第一次付费我才会有推荐费..
```
once they pay their first bill or purchase credits.
```
lux182
2023-03-23 17:28:27 +08:00
流弊

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/926542

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX