本文转自: https://saika.us.kg/2024/01/27/serv00_logs/
仅做个人收藏,版权归原作者所有
这个平台是个 Virtual Host ,没有 Root ,还是 FreeBSD 的系统,不是 Linux ,不太好用。但是优点是隔离性差, Memory 和 vCPU 能短时间内超过 100% 进行调用。
已经玩了不少时间了,起初看到 Github 上有使用 Serv00 搭建 Vless 节点的仓库,就上手玩了一下,后来发现极其不稳, screen 运行的进程总是过一段时间就掉了(后经网友讨论确认为Serv00有时候会重启宿主机),又得ssh上去启动,相当不友好,且后来又发现了 Hax 这样的玩具,就对 Serv00 视如敝履了。
但是这两天有群友突然提醒我才想起,我在 Hax 上用的很舒服的 pm2 也可以在 Serv00 上使用,这个十年有效期的玩具突然显得有用了起来。
经过我的尝试,成功在 Serv00 上部署了一些服务,接下来进行记录:
面板自带功能
域名
Serv00 上如果想要使用自己的域名,有两种方式,一种是通过 Cloudflare 提供的 Argo 隧道,不仅能绑域名,免配置 ssl ,还可以享受 Cloudflare 的免费 CDN 提速。第二种就是直接使用面板内自带的 DNS 服务器功能绑定自己的域名。
在 Panel 中进入 DNS zones 选项卡,使用 Add new zone 功能添加自己的域名或者自己的域名的子域,然后在 Zone list 中找到刚刚添加的域名,点击 Edit 查看 DNS 记录,把当中列出的全部记录添加到自己的域名的 DNS 记录中即可完成域名的绑定。
Serv00 本身对于绑定在其上的域名提供了许多的服务支持,这里所说的绑定在Serv00上的域名包括自己绑定的自己的域名,以及 Serv00 在注册账户时赠送的域名 USERNAME.serv00.net
,其服务包括免费的一键申请式的 SSL 证书、域名邮箱、 DNS 管理等多种功能。
SSL证书申请
在 Panel 中进入 WWW websites 选项卡,点击 Manage SSL certificates ,在你需要申请 SSL 证书的域名的 A 记录指向的那个 IP 地址右侧点击 Manage ,再点击 Add certificate , Type 选择 Generate Let’s Encrypt certificate ,Domain 选择要申请 SSL 证书的域名,再点击 Add 即可。
域名邮箱
Panel 中进入 E-mail 选项卡,注册账号后会自动注册一个域名邮箱,用户名是 [email protected]
是 Serv00 的账户密码。可以使用 Add new e-mail 功能新建邮箱账户。
也可以在 Add new alias 功能中新建别名邮箱,其别名邮箱功能也提供了和 Cloudflare 一样的 Catch-all 的 Advanced settings 选项,用来批量注册东西十分方便。
目前我的测试中,似乎没有在 Manage whitelist 中添加进白名单的域名邮箱发来的邮件全部都会被识别为垃圾邮件。所以有需要的话可以在 Manage whitlist 中添加你需要接受邮件的邮箱的域名,比如 qq.com
、 gmail.com
等等。
如果绑定了自己的域名,想要使用自己的域名配置域名邮箱的话,要在 Domain list 中找到自己的域名,点击最右边的 DKIM , action 选择 Add DNS record automatically ,然后 Sign domain 以注册域名,使得新的域名邮箱能够通过一些邮件接收服务器的验证。
Open web client 功能就可以进入邮箱的登录页面了,其使用方法与大多数的邮箱相同,不再赘述。
DNS管理
DNS zones 选项卡中在自己绑定的域名右侧点击 Edit ,即可查看当前域名的所有 DNS 记录,在 Add new record 中可以手动添加新的 DNS 记录,与大多数的域名服务商提供的 DNS 管理的功能类似。
Proxy
WWW websites 选项卡中可以根据语言不同添加多种网站,其中 PHP 的 eval() function
和 exec() function
都要在添加完网站后,在Manage > Details 中打开。不同类型的网页其 Details 中的选项也都有差异,可以按需查看配置,这里重点讲一下 Proxy 类型指向自己的应用程序监听端口的配置。
Add new website 功能中, Domain 填写自己的域名或者 serv00 分配的域名,或者它们的子域,展开 Advanced settings, Website type 选择 Proxy ,Proxy target 选择 localhost , Proxy port 选择自己的应用监听的端口,其他选项留空或者保持默认,点击 Add 即可。接下来就能使用刚刚填写的域名访问自己部署的对应端口的应用了。如果需要 https 访问,再按前文的步骤去申请 SSL 证书即可。
运行自己的应用
Additional services 选项卡中找到 Run your own applications 项目,将其设置为 Enabled 即可。如果不开启这一项,自己的用户目录下的所有文件都无法添加可执行权限。
File manager
文件管理,有一定的在线编辑和预览的功能,兼具文件的上传下载,删除新建等各种管理功能,十分便利。
Port reservation
需要使用端口都得在这申请。
数据库
Serv00 提供了 MySQL 、 PostgreSQL 、 MongoDB 三种数据库,可以按需新建数据库、数据库用户。同时, Serv00 还提供了三种数据库的 webui ,十分便利。
需要注意的是,所有数据库在新建时,其用户名和数据库名都有一个 mxxx_
的前缀,在使用时容易被忽视。
Cron jobs
Cron jobs 选项卡提供了一些计划性任务的设置功能,在这里可以设置开机自启任务,或者定时循环任务,当然常用的还是开机自启任务的设定, Specify time 选择 After reboot 即为开机自启。
部署应用前的一些准备工作
在部署自己的应用之前,我建议提前安装好 pm2 以及 Cloudflared (可选)。前者是进程管理工具,用来方便开机自启,以及程序崩溃后自启,查阅进程运行情况等等。后者是 Cloudflare 的 Argo 隧道客户端,用它也可以给自己部署的应用加域名。特别是 Uptime Kuma ,更加推荐使用 Cloudflared 加域名,而不建议使用面板自带的 Proxy 。
Pm2
这个是重中之重,如果不是成功安装了 pm2 ,我甚至不会尝试探索 Serv00 这个玩具有什么用,所以 pm2 的安装方法记录在开头。
在 SSH 连接 serv00 之后,直接使用一键脚本安装 pm2 :
1 |
bash <(curl -s https://raw.githubusercontent.com/k0baya/alist_repl/main/serv00/install-pm2.sh) |
如果安装完成后执行
pm2
提示命令未找到,你可以断开 SSH 连接,再重新连接,即可。
Cloudflared
Cloudflared 官方仓库并没有构建 FreeBSD 系统上能够使用的二进制文件,但是同样的,我找到了第三方的构筑。使用第三方构筑的二进制文件,就能愉快的使用隧道了。
关于 Cloudflared 是什么,有什么用,ARGO_TOKEN 如何获取等部分,这里不再赘述,详细可以查看我的关于 CodeSandbox 和 Hax 的文章。
创建并进入Cloudflared 的工作目录:
1 |
mkdir -p ~/domains/cloudflared && cd ~/domains/cloudflared |
下载 Cloudflared:
1 |
wget https://cloudflared.bowring.uk/binaries/cloudflared-freebsd-latest.7z && 7z x cloudflared-freebsd-latest.7z && rm cloudflared-freebsd-latest.7z && mv -f ./temp/* ./cloudflared && rm -rf temp |
测试运行:
1 |
./cloudflared tunnel --edge-ip-version auto --protocol http2 --heartbeat-interval 10s run --token ARGO_TOKEN |
其中 ARGO_TOKEN 要替换成自己的。确定运行没有问题后,按
Ctrl+c
即可停止运行。
使用 pm2 启动 Cloudflared:
1 |
pm2 start ./cloudflared -- tunnel --edge-ip-version auto --protocol http2 --heartbeat-interval 10s run --token ARGO_TOKEN |
其中 ARGO_TOKEN 要替换成自己的。
接着去 CLoudflare 的面板中设置域名对应端口,即可使用域名访问自己搭建的服务了。
安装 go1.22
如果你有安装自己使用 go build 构建的需求,你可以选择安装最新的 go1.22 ,这里记录其安装过程。
由于 Serv00 服务器上并未提供 go1.22 ,只提供了 go1.20.3 ,无法正常进行构建工作,所以需要手动安装 go1.22 环境。
1 |
# 创建安装目录 |
部署自己的应用
关于设定 PHP 版本、插件、参数等配置均可参考文档的 .htaccess 部分进行配置,由于 PHP 的应用部署实在是太简单,故本文不会过多介绍。
WordPress
实际上在 serv00 的文档中有搭建网站的示例,没错,示例就有 WordPress ,实际上 WordPress 确实可以搭建,十分简单好用。这里不做过多介绍,按照文档一步步操作即可。
除了 WordPress 外,文档中还详细介绍了 Redis、Memcached、Imapsync、WP-CLI、Tomcat 等服务的搭建方法,有需求的都可以照着抄。
KodBox
虽然 Serv00 能够部署 KodBox,但是实在是不太好用。最直观的感受就是卡,因为 KodBox 运行期间需要调用多个 PHP 组件,而 Serv00 限制同时处理三个 PHP 进程,所以显得特别慢。其次, Serv00 没有 Root 权限,部分 PHP 插件没有安装,也无法安装,导致有一些 KodBox 的插件无法正常运行。
当然如果只是图新奇搭一个玩玩,也是可以的。下面是步骤:
首先在 Panel 中 Add a New Website :
Key | Value |
---|---|
Domain | xxx.USERNAME.serv00.net (也可以把原有的USERNAME.serv00.net删掉后重新添加) |
Website Type | PHP |
添加完新站点后,继续点击上方的 Manage SSL certificates ,接着在出口 IP 的右侧点击 Manage ,再点击 Add certificate :
Type | Domain |
---|---|
Generate Let’s Encrypted certificate | 与刚刚添加的站点域名保持一致(如果是原有的USERNAME.serv00.net ,可以省略此步) |
接着SSH登入,并进入刚刚你新建的域名目录下的 public_html
路径下:
1 |
# 安装KodBox |
然后去 Panel 中的 MySQL 选项卡,新建数据库和用户,用以接入 KodBox 。再去 WWW Websites 选项卡中找到 用户名.serv00.net ,点击右侧的 Manage > Details 进入设置,把 GZIP compression、Allow PHP eval() function、Allow PHP exec() function 三个功能打开。
然后使用浏览器访问你的 KodBxo 的域名,进行安装配置即可。初次启动需要较长的时间,请耐心等待。
Lsky-Pro
一开始看兰空图床的文档没看到 webdav 功能的相关介绍,只看到几个我都不用的存储介质,遂不感兴趣的搁置了,然而群友近日又提起,我打开 GitHub 才发现首页有个 Commit 的标题就是 webdav 相关,即兰空图床支持 webdav 。于是我便部署了一下,体验感觉还不错,简单易用。
本来无意在本篇文章再多写 PHP 相关的站点部署,因为过于简单。但是奈何群友有需求,遂做个简单的步骤记录:
首先在 Panel 中 Add a New Website :
Key | Value |
---|---|
Domain | xxx.USERNAME.serv00.net (也可以把原有的USERNAME.serv00.net删掉后重新添加) |
Website Type | PHP |
添加完新站点后,继续点击上方的 Manage SSL certificates ,接着在出口 IP 的右侧点击 Manage ,再点击 Add certificate :
Type | Domain |
---|---|
Generate Let’s Encrypted certificate | 与刚刚添加的站点域名保持一致(如果是原有的USERNAME.serv00.net ,可以省略此步) |
接着SSH登入,并进入刚刚你新建的域名目录下:
1 |
# 下载图床应用 |
接着在 Panel 中 WWW websites 选项卡内,点击自己刚刚创建的用于部署 Lsky-Pro 的域名的 Manage > Details ,在 Open Basedir directories 的最末添加:
1 |
:/usr/home/用户名/domains/xxx.USERNAME.serv00.net |
记得把用户名和最末的域名换成自己的。
然后把 GZIP compression 、Allow PHP eval() function 、Allow PHP exec() function 都打开,点击 save changes 保存。
然后去 Panel 中的 MySQL 选项卡,新建数据库和用户,用以接入 Lsky-Pro 。
然后使用浏览器访问你的 Lsky-Pro 的域名,进行安装配置即可。
上面的应用不需要占用端口。
下面的应用每一个都能够 / 需要占用端口。
Vless
这个肯定是第一时间部署的,每次遇到这样的平台,第一时间总是想着能不能搭建节点。
①
首先在 Panel 中放行一个端口,接着按照下表 Add a New Website :
Key | Value |
---|---|
Domain | xxx.USERNAME.serv00.net (也可以把原有的 USERNAME.serv00.net 删掉后重新添加) |
Website Type | proxy |
Proxy Target | localhost |
Proxy URL | 留空 |
Proxy port | 你准备用来部署 Vless 的端口 |
Use HTPPS | False |
DNS support | True |
添加完新站点后,继续点击上方的 Manage SSL certificates ,接着在出口 IP 的右侧点击 Manage ,再点击 Add certificate :
Type | Domain |
---|---|
Generate Let’s Encrypted certificate | 与刚刚添加的站点域名保持一致(如果是原有的USERNAME.serv00.net ,可以省略此步) |
接着SSH登入,并进入刚刚你新建的域名目录下:
1 |
# 克隆源仓库 |
使用vim编辑或者直接去 Panel 中的 File Manager 选项卡在线编辑 app.js
文件,修改端口为刚刚放行的端口。
安装依赖:
1 |
npm install |
安装完毕后,使用pm2启动并守护vless进程:
1 |
pm2 start app.js --name vless |
接着去你的代理客户端软件中手动添加 vless 配置即可:
Key | Value |
---|---|
地址 | Panel中WWW Websites 选项卡里的你的 Domain name |
端口 | 你放行的端口 |
用户 id | 37a0bd7c-8b9f-4693-8916-bd1e2da0a817 |
传输协议 | ws |
伪装域名 | 同地址 |
ws path | / |
上表没有给出的可以不填。
②
首先在 Panel 中放行一个端口,接着按照下表 Add a New Website :
Key | Value |
---|---|
Domain | xxx.USERNAME.serv00.net (也可以把原有的 USERNAME.serv00.net 删掉后重新添加) |
Website Type | proxy |
Proxy Target | localhost |
Proxy URL | 留空 |
Proxy port | 你准备用来部署 Vless 的端口 |
Use HTPPS | False |
DNS support | True |
添加完新站点后,继续点击上方的 Manage SSL certificates ,接着在出口 IP 的右侧点击 Manage ,再点击 Add certificate :
Type | Domain |
---|---|
Generate Let’s Encrypted certificate | 与刚刚添加的站点域名保持一致(如果是原有的USERNAME.serv00.net ,可以省略此步) |
接着SSH登入,并进入刚刚你新建的域名目录下的 public_html
路径下,再使用 npm
命令安装 @3Kmfi6HP/nodejs-proxy
:
1 |
npm install @3Kmfi6HP/nodejs-proxy |
被删库了可以自己换个源安装,比如:
1 npm --registry http://r.cnpmjs.org install @3Kmfi6HP/nodejs-proxy这个源如果也不行了请自己找其他源替换。
再使用 pm2 启动:
1 |
# 记得把 PORT 替换成自己放行的端口。 |
接着访问这个刚刚添加的站点,即可在网页上直接获取配置。
哦对,有个小 bug
,端口需要改成 443 ,而网页中默认给的配置是 80 。
之所以说这个
npm
包不安全,是因为其配置在网页上都可以看到,而且网页设计不太合理,有一个不带uuid
的中转页面,所以可以使用 fofa 、 shodan 等网络空间扫描工具批量扫出来,而且不止 Serv00 一个平台有人使用,如果你感兴趣,你可以去搜搜看,可以收获一大批 Vless 节点。这里放一个 Serv00 上的,我在 fofa 上搜到的页面作为部署示例:https://pclwgdwv.serv00.net/
Alist
Alist 官方仓库没有构筑 FreeBSD 系统下能够运行的 Alist 可执行文件,但是我在 Github 上发现了一个使用 Github Workflow 自动构筑 FreeBSD 适用的 Alist 的仓库,使用这个仓库就可以很便利的在Serv00上部署 Alist。
首先在 Panel 中放行一个端口,接着按照下表 Add a New Website :
Key | Value |
---|---|
Domain | xxx.USERNAME.serv00.net (也可以把原有的 USERNAME.serv00.net 删掉后重新添加) |
Website Type | proxy |
Proxy Target | localhost |
Proxy URL | 留空 |
Proxy port | 你准备用来部署 Alist 的端口 |
Use HTPPS | False |
DNS support | True |
添加完新站点后,继续点击上方的 Manage SSL certificates ,接着在出口 IP 的右侧点击 Manage ,再点击 Add certificate :
Type | Domain |
---|---|
Generate Let’s Encrypted certificate | 与刚刚添加的站点域名保持一致(如果是原有的USERNAME.serv00.net ,可以省略此步) |
接着 SSH 登入,并进入刚刚你新建的域名目录下的 public_html
路径下:
1 |
# 使用一键命令安装 Alist |
在 Panel 中进入 MySQL 选项卡,使用 Add database 功能新建一个数据库。
密码要求含有大写字母、小写字母和数字三种字符,且长度必须超过6个字符。
接下来进入 File manager 选项卡,进入 ~/domains/xxx.USERNAME.serv00.net/public_html/data
路径,可以看到一个名为 config.json
的文件,右键点击,选择 View/Edit > Source Editor ,进行编辑:
我主要修改了 CDN、database、scheme 三个部分,其中CDN可以在 Alist 的官方文档找到,请选择你本地网络连接速度最快的一个。
scheme 部分,我选择修改 adress 为 127.0.0.1
本地回环,是为了避免被他人使用 http://ip:port
的方式进行访问。至于自己怎么访问,我在本文后面的部分会进行介绍。port 要改成自己前面放行的端口。
database 部分,type 需要改成 mysql
,host 填写你在注册邮件中看到的 mysql 的地址, port 是默认的 3306,用户名、密码、数据库名则按照你创建的情况进行填写。
最新版本的 Alist 如果不想开启 S3 Server,请把对应的配置文件中的端口配置为 0 。
改完之后,点击 save 保存,接着回到 SSH 窗口中进行操作:
测试启动 Alist:
1 |
./alist server |
确定运行没有问题后,按
Ctrl+c
即可停止运行。
使用 pm2 启动并管理 alist:
1 |
pm2 start ./alist -- server |
同样的,你还可以使用 Cloudflared 隧道添加域名,而不选择使用 Proxy 。
Synctv
群友仿照 alist-freebsd 的仓库的 workflow 进行构筑的。部署简单,与 alist 类似。首先在 Panel 中放行一个端口,接着按照下表 Add a New Website :
Key | Value |
---|---|
Domain | xxx.USERNAME.serv00.net (也可以把原有的 USERNAME.serv00.net 删掉后重新添加) |
Website Type | proxy |
Proxy Target | localhost |
Proxy URL | 留空 |
Proxy port | 你准备用来部署 Synctv 的端口 |
Use HTPPS | False |
DNS support | True |
添加完新站点后,继续点击上方的 Manage SSL certificates ,接着在出口 IP 的右侧点击 Manage ,再点击 Add certificate :
Type | Domain |
---|---|
Generate Let’s Encrypted certificate | 与刚刚添加的站点域名保持一致(如果是原有的USERNAME.serv00.net ,可以省略此步) |
接着 SSH 登入,并进入刚刚你新建的域名目录下的 public_html
路径下:
1 |
# 下载可执行文件 |
新建启动脚本:
1 |
cat > start.sh << EOF |
添加可执行权限:
1 |
chmod +x start.sh |
测试运行:
1 |
./start.sh |
确定运行没有问题后,按
Ctrl+c
即可停止运行。
使用pm2启动并管理:
1 |
pm2 start ./start.sh --name synctv |
同样的,你还可以使用 Cloudflared 隧道添加域名,而不选择使用 Proxy 。
One-api
源仓库没有提供freebsd平台的二进制文件,需要自己构建,但是很简单。我已经写了一个仓库用于自动化构建 freebsd 版本的 one-api 二进制文件,可以直接下载使用。
如果你想使用 New-API ,可以使用这个仓库k0baya/new-api-freebsd,用法与本节介绍的 One-API 基本一致,对比One-API添加了一些更方便的功能。也许之后 One-API 也会加入这些功能。
首先在 Panel 中放行一个端口,接着按照下表 Add a New Website :
Key | Value |
---|---|
Domain | xxx.USERNAME.serv00.net (也可以把原有的USERNAME.serv00.net删掉后重新添加) |
Website Type | proxy |
Proxy Target | localhost |
Proxy URL | 留空 |
Proxy port | 你准备用来部署 One-API 的端口 |
Use HTPPS | False |
DNS support | True |
添加完新站点后,继续点击上方的 Manage SSL certificates ,接着在出口 IP 的右侧点击 Manage ,再点击 Add certificate :
Type | Domain |
---|---|
Generate Let’s Encrypted certificate | 与刚刚添加的站点域名保持一致(如果是原有的USERNAME.serv00.net ,可以省略此步) |
接着 SSH 登入,并进入刚刚你新建的域名目录下的 public_html
路径下:
1 |
# 下载 one-api |
新建启动脚本:
1 |
cat > start.sh << EOF |
添加可执行权限:
1 |
chmod +x start.sh |
保存后回到 terminal 中,测试运行:
1 |
./start.sh |
确定运行没有问题后,按
Ctrl+c
即可停止运行。
使用pm2启动并管理:
1 |
pm2 start ./start.sh --name one-api |
同样的,你还可以使用 Cloudflared 隧道添加域名,而不选择使用 Proxy 。
Uptime-Kuma
受限于 FreeBSD 的平台限制,1.23版本内置了 PlayWright ,无法运行,所以只能安装 1.22 版本。切记先去 Panel 中放行 TCP 端口。
首先在 Panel 中放行一个端口,接着按照下表 Add a New Website :
Key | Value |
---|---|
Domain | xxx.USERNAME.serv00.net (也可以把原有的USERNAME.serv00.net删掉后重新添加) |
Website Type | proxy |
Proxy Target | localhost |
Proxy URL | 留空 |
Proxy port | 你准备用来部署 Uptime-Kuma 的端口 |
Use HTPPS | False |
DNS support | True |
添加完新站点后,继续点击上方的 Manage SSL certificates ,接着在出口 IP 的右侧点击 Manage ,再点击 Add certificate :
Type | Domain |
---|---|
Generate Let’s Encrypted certificate | 与刚刚添加的站点域名保持一致(如果是原有的USERNAME.serv00.net ,可以省略此步) |
接着 SSH 登入,并进入刚刚你新建的域名目录下:
1 |
# 下载 v1.22.1 版本的源代码 |
设置生产模式:
1 |
npm ci --production |
下载dist文件:
1 |
wget https://github.com/louislam/uptime-kuma/releases/download/1.22.1/dist.tar.gz && tar -xzvf dist.tar.gz && rm dist.tar.gz |
安装补充依赖:
1 |
npm install |
安装过程中多少会有报错,无视就好,实际上最后可以正常运行。内置的Cloudflared反向代理在FreeBSD平台上无法使用,但是可以使用上述的外置的Cloudflared进行反代,使用自己的域名。
测试运行:
1 |
node server/server.js --port=PORT |
记得把PORT替换成你放行的端口。确定运行没有问题后,按
Ctrl+c
即可停止运行。
使用pm2管理后台运行:
1 |
pm2 start server/server.js --name uptime-kuma -- --port=PORT |
记得把PORT替换成你放行的端口。
如果你不希望自己的Uptime-Kuma被人使用
http://IP:PORT
的方式访问,你可以在最后的执行命令添加--host=127.0.0.1
的尾缀,这样就只能通过反向代理的域名进行访问了:
1 pm2 start server/server.js --name uptime-kuma -- --port=PORT --host=127.0.0.1
同样的,你还可以使用 Cloudflared 隧道添加域名,而不选择使用 Proxy 。
Bingo(暂时无法正常使用)
先放行一个端口。在 Panel 中进入 File manager 选项卡,点击左侧的 My Files 进入你的用户根目录,找到 .profile
文件,右键选择 View/Edit > Choose other >Source Editor 进行编辑,在最末加上以上两行并保存:
1 |
alias node='node20' |
应用更改:
1 |
source ~/.profile |
先新建一个目录用于存放 Bingo 的相关文件,进入目录后执行下述操作。
下载源码:
1 |
git clone https://github.com/weaigc/bingo |
进入源码所在目录:
1 |
cd bingo |
安装依赖:
1 |
npm20 install |
下载build好的 .next
资源:
1 |
wget -O next.tar.gz https://pan.saika.free.hr/d/local/next.tar.gz && tar -xzvf next.tar.gz && rm next.tar.gz |
添加环境变量文件:
1 |
cp .env.example .env |
接着在 Panel 中进入 File manager 选项卡,进入Bingo 源码所在的目录,找到 server.js
文件,右键选择 View/Edit > Choose other >Source Editor 进行编辑,修改第7行中的端口为你放行的端口。再编辑 .env
文件,添加你的 BING_HEADER
。
测试启动:
1 |
npm20 run start |
确定运行没有问题后,按
Ctrl+c
即可停止运行。
使用pm2启动并管理:
1 |
pm2 start npm --name bingo -- run start |
Refresh-gpt-chat
用来对接 ninja、warpgpt 等能够使用 access_Token 作为 API Key 请求 GPT 的工具,以使用永久有效期的 Refresh_token 来获取更好的体验。
首先在 Panel 中放行一个端口,接着按照下表 Add a New Website :
Key | Value |
---|---|
Domain | xxx.USERNAME.serv00.net (也可以把原有的 USERNAME.serv00.net 删掉后重新添加) |
Website Type | proxy |
Proxy Target | localhost |
Proxy URL | 留空 |
Proxy port | 你准备用来部署 Refresh-gpt-chat 的端口 |
Use HTPPS | False |
DNS support | True |
添加完新站点后,继续点击上方的 Manage SSL certificates ,接着在出口 IP 的右侧点击 Manage ,再点击 Add certificate :
Type | Domain |
---|---|
Generate Let’s Encrypted certificate | 与刚刚添加的站点域名保持一致(如果是原有的USERNAME.serv00.net ,可以省略此步) |
接着 SSH 登入,并进入刚刚你新建的域名目录下的 public_html
路径下:
1 |
# 下载 refresh-gpt-chat |
使用 pm2 启动:
1 |
pm2 start java19 --name refresh-gpt-chat -- -jar refresh-gpt-chat.jar --server.port=端口 --server.servlet.context-path=/ --getAccessTokenUrl=https://你的ninja地址/auth/refresh_token --chatUrl=https://你的ninja地址/v1/chat/completions |
再套域名,接下来就可以直接使用 https://你套的域名/v1/chat/completions/
当作API端点,使用 refresh_token
做 API_Keys ,使用 ChatGPT 了。
然后在 one-api 中添加自定义渠道, Base URL
填写你 https://你套的域名
,模型填入你的 refresh_token 对应的账号所支持的模型,如果和我一样手持大把 3.5 的账号想用来做 API 用,可以选择全部 GPT3.5 的相关模型,然后在 模型重定向
中填入以下内容:
1 |
{ |
密钥填写你的 refresh_token
即可,如果你有多个账号,可以将批量勾选上,然后一行写一个 refresh_token
。
同样的,你还可以使用 Cloudflared 隧道添加域名,而不选择使用 Proxy 。
Gpt4-copilot-java
支持 cocopilot 的 ccu 和 copilot 的 ghu 调用 copilot 转 GPT-4 的接口转换工具。 Java 写的,可以在 Serv00 运行。
目前更推荐这个方法:lvguanjun/copilot-to-chatgpt4
比起 Gpt4-copilot-java 更轻量更强大。
首先在 Panel 中放行一个端口,接着按照下表 Add a New Website :
Key | Value |
---|---|
Domain | xxx.USERNAME.serv00.net (也可以把原有的USERNAME.serv00.net删掉后重新添加) |
Website Type | proxy |
Proxy Target | localhost |
Proxy URL | 留空 |
Proxy port | 你准备用来部署 Gpt4-copilot-java 的端口 |
Use HTPPS | False |
DNS support | True |
添加完新站点后,继续点击上方的 Manage SSL certificates ,接着在出口 IP 的右侧点击 Manage ,再点击 Add certificate :
Type | Domain |
---|---|
Generate Let’s Encrypted certificate | 与刚刚添加的站点域名保持一致(如果是原有的USERNAME.serv00.net ,可以省略此步) |
接着 SSH 登入,并进入刚刚你新建的域名目录下的 public_html
路径下:
1 |
# 下载 fat jar 包 |
测试运行:
1 |
# 把PORT改为自己放行的端口,最后的server.servlet.context-path参数可以改成自己喜欢的尾缀 |
测试没有问题之后,按
Ctrl+c
即可停止运行。
使用 pm2 启动并管理:
1 |
pm2 start java19 --name gpt4-copilot-java -- -jar gpt4-copilot-java.jar --server.port=PORT --server.servlet.context-path=/ |
始皇的公车:ghu_ThisIsARealFreeCopilotKeyByCoCopilot (已失效)
免费公车白嫖请求示例:
1
2
3
4
5
6
7 curl --location 'http(s)://ip:port_or_URL/cocopilot/v1/chat/completions'
--header 'Content-Type: application/json'
--header 'Authorization: Bearer ghu_ThisIsARealFreeCopilotKeyByCoCopilot'
--data '{
"model": "gpt-4",
"messages": [{"role": "user", "content": "鲁迅打周树人"}]
}'
同样的,你还可以使用 Cloudflared 隧道添加域名,而不选择使用 Proxy 。
Zfile
首先在 Panel 中放行一个端口,接着按照下表 Add a New Website :
Key | Value |
---|---|
Domain | xxx.USERNAME.serv00.net (也可以把原有的USERNAME.serv00.net删掉后重新添加) |
Website Type | proxy |
Proxy Target | localhost |
Proxy URL | 留空 |
Proxy port | 你准备用来部署 Zfile 的端口 |
Use HTPPS | False |
DNS support | True |
添加完新站点后,继续点击上方的 Manage SSL certificates ,接着在出口 IP 的右侧点击 Manage ,再点击 Add certificate :
Type | Domain |
---|---|
Generate Let’s Encrypted certificate | 与刚刚添加的站点域名保持一致(如果是原有的USERNAME.serv00.net ,可以省略此步) |
接着 SSH 登入,并进入刚刚你新建的域名目录下的 public_html
路径下:
1 |
# 下载 fat jar 包 |
测试运行:
1 |
java19 -jar -Duser.timezone=Asia/Shanghai zfile.jar --zfile.log.path=$PWD/logs --zfile.db.path=$PWD/zfile --server.port=PORT |
记得把端口改成自己的。测试没有问题之后,按
Ctrl+c
即可停止运行。
使用pm2启动并管理:
1 |
pm2 start java19 --name zfile -- -jar -Duser.timezone=Asia/Shanghai zfile.jar --zfile.log.path=$PWD/logs --zfile.db.path=$PWD/zfile --server.port=PORT |
同样的,你还可以使用 Cloudflared 隧道添加域名,而不选择使用 Proxy 。
Halo
慎重部署,内存会超100%,不知道会不会封号
halo 自从升级 2.0 版本开始,很长时间内都没有提供构筑好的 jar 包,甚至于在GitHub上都出现了第三方的,使用 GitHub workflow 自动化构筑 jar 包的仓库。但是,自从2.12.0-alpha.1版本开始,halo 的官方仓库又开始提供构筑好的 jar 包了,刚好这些天在玩 Serv00 ,遂尝试部署了一下,成功。现记录一下:
首先在 Panel 中放行一个端口,接着按照下表 Add a New Website :
Key | Value |
---|---|
Domain | xxx.USERNAME.serv00.net (也可以把原有的 USERNAME.serv00.net 删掉后重新添加) |
Website Type | proxy |
Proxy Target | localhost |
Proxy URL | 留空 |
Proxy port | 你准备用来部署 Halo 的端口 |
Use HTPPS | False |
DNS support | True |
添加完新站点后,继续点击上方的 Manage SSL certificates ,接着在出口 IP 的右侧点击 Manage ,再点击 Add certificate :
Type | Domain |
---|---|
Generate Let’s Encrypted certificate | 与刚刚添加的站点域名保持一致(如果是原有的USERNAME.serv00.net ,可以省略此步) |
并在 MySQL 选项卡中中新建 MySQL 数据库,用于填入接入 Halo 。
接着 SSH 登入,并进入刚刚你新建的域名目录下的 public_html
路径下:
1 |
# 下载jar包 |
在 halo.jar
所在路径下新建 .halo2
文件夹,进入其中,新建文件 application.yaml
然后并配置其内容:
1 |
# 新建文件夹 |
在 halo.jar
所在路径下新建 run.sh
运行脚本:
1 |
cat > run.sh << EOF |
测试运行:
1 |
chmod +x run.sh && ./run.sh |
确定运行没有问题后,按
Ctrl+c
即可停止运行。
使用pm2管理运行:
1 |
chmod +x run.sh && pm2 start ./run.sh --name halo |
同样的,你还可以使用 Cloudflared 隧道添加域名,而不选择使用 Proxy 。
Go-proxy-bingai
这个仓库是 Bingo 的前身,当初玩 Replit 时我便有在使用,只可惜作者早已弃坑,所以当初我才找到了当时还能用的 Bingo 使用。
在 Bingo 也长期未更新,无法正常使用的如今,我的目光转向了另一个二改仓库。Harry-zklcdc 维护的 Go-proxy-bingai 的分支仓库目前还能够正常使用。而且在与开发者反馈了几个 bug 之后,开发者都会花时间认真复现,并快速修复,其体验实在是不错。
虽然原仓库的 Release 中并未提供 FreeBSD 系统适用的二进制文件,但是我们能够自己构建。我已经构建了一份放在这篇博客底部的QQ群的群文件中。我写了一个仓库用于自动化构建 FreeBSD 版本的 go-proxy-bingai ,可以从我的仓库下载使用。 作者已经开始提供 FreeBSD 的构建,故我的仓库已经存档。
首先在 Panel 中放行一个端口,接着按照下表 Add a New Website :
Key | Value |
---|---|
Domain | xxx.USERNAME.serv00.net (也可以把原有的 USERNAME.serv00.net 删掉后重新添加) |
Website Type | proxy |
Proxy Target | localhost |
Proxy URL | 留空 |
Proxy port | 你准备用来部署 Go-proxy-bingai 的端口 |
Use HTPPS | False |
DNS support | True |
添加完新站点后,继续点击上方的 Manage SSL certificates ,接着在出口 IP 的右侧点击 Manage ,再点击 Add certificate :
Type | Domain |
---|---|
Generate Let’s Encrypted certificate | 与刚刚添加的站点域名保持一致(如果是原有的USERNAME.serv00.net ,可以省略此步) |
接着 SSH 登入,并进入刚刚你新建的域名目录下的 public_html
路径下:
1 |
# 下载可执行文件 |
新建启动脚本:
1 |
cat > entrypoint.sh << EOF |
运行:
1 |
# 测试运行 |
请注意,如果你需要使用其 web 功能,而不仅仅是 api 功能,请务必使用 https 访问,不然无法打开。你可以选择使用面板自带的 proxy 添加域名并申请 ssl 证书,亦或者直接使用 cloudflared 隧道。
同样的,你还可以使用 Cloudflared 隧道添加域名,而不选择使用 Proxy 。
Pentaract
不建议使用,目前 Bug 众多,而且对 Telegram 账号有一定要求,目前暂不清楚 Telegram 限制账号的评定标准。
可以自行构建或者使用使用我构建的成品。由于该应用需要使用具有超级管理员权限的 PostgreSQL ,故不可使用 Serv00 自带的 PostgreSQL ,需要远程连接。
编译成品下载地址:pentaract-freebsd_X64.tar.gz
前端构建简单,这里不再赘述,而且由于其 Dockerfile
内构建前端使用的是 Node.js 21 而目前 FreeBSD Port 最高只有 Node.js 20 ,故不推荐在 FreeBSD 上直接构建,可以使用 GItHub Actions 进行构建,或是自己在 Node.js 21 的环境下构建再复制,甚至干脆直接从作者预构建的 Docker 镜像内打包出来使用。(经过测试,使用 Nodejs20 构建也可以正常使用。)
Serv00 上的构建法:
1 |
# 切换 Node.js 版本为 Nodejs20 |
后端的构建,可以使用 GItHub Actions ,或者本地 FreeBSD 虚拟机,甚至直接在 Serv00 上构建。这里记录一下在 Serv00 上构建的方法:
1 |
# 克隆仓库到 Serv00 上 |
然后去 supabase 注册一个免费的PostgreSQL ,记录下数据库的用户名、密码、数据库名、地址,用于后续填入环境变量。
接着在 ~/pentaract
路径下新建一个启动脚本,按照要求填入所有的环境变量:
1 |
cat > start.sh << EOF |
给启动脚本赋权:
1 |
chmod +x start.sh |
前端的 已经重新构建前端并替换,现无需此步。index-22eec6d1.js
文件内的 http://localhost:8000
需要更改为 serv00 的 url 或者 ip:port 。你可以去文件管理中编辑,查找替换即可,也可以使用sed命令简单更改一下:
测试运行:
1 |
./start.sh |
使用 pm2 管理:
1 |
pm2 start ./start.sh --name pentaract |
OneList
原作者似乎已经弃坑,故我的仓库没有做自动检测构建。但是体验还不错,有 Emby 既视感了,配合小雅的 Alist 岂不美哉。
首先在 Panel 中放行一个端口,接着按照下表 Add a New Website :
Key | Value |
---|---|
Domain | xxx.USERNAME.serv00.net (也可以把原有的USERNAME.serv00.net删掉后重新添加) |
Website Type | proxy |
Proxy Target | localhost |
Proxy URL | 留空 |
Proxy port | 你准备用来部署 OneList 的端口 |
Use HTPPS | False |
DNS support | True |
添加完新站点后,继续点击上方的 Manage SSL certificates ,接着在出口 IP 的右侧点击 Manage ,再点击 Add certificate :
Type | Domain |
---|---|
Generate Let’s Encrypted certificate | 与刚刚添加的站点域名保持一致(如果是原有的USERNAME.serv00.net ,可以省略此步) |
接着SSH登入,并进入刚刚你新建的域名目录下的 public_html
路径下:
1 |
# 下载 OneList |
接着回到 Panel 中,进入File manager选项卡,进入 OneList 所在路径,可以看到一个名为 config.env
的文件,右键点击,选择View/Edit > Source Editor,进行编辑:
1 |
# 服务设置 |
你可以按照自己的需求配置端口、管理员账户、数据库。 MySQL 性能更好哦~
测试运行:
1 |
./onelist -run server |
使用 pm2 管理:
1 |
pm2 start ./onelist -- -run server |
WarpGPT
这个没什么多说的,可以使用 access_Token 作为 API Key 请求 ChatGPT 接口,也就是所谓的 chat2api 。配合前文的 Refresh-gpt-chat 就可以把永久有效期的 Refresh_token 作为 API Key 来使用,十分的好用。
源仓库没有 Release ,故我的仓库没有做自动检测构建。如果有更新需求需要手动触发 workflow 。你有需要也可以自己fork一份然后手动触发 workflow 。
首先在 Panel 中放行一个端口,接着按照下表 Add a New Website :
Key | Value |
---|---|
Domain | xxx.USERNAME.serv00.net (也可以把原有的USERNAME.serv00.net删掉后重新添加) |
Website Type | proxy |
Proxy Target | localhost |
Proxy URL | 留空 |
Proxy port | 你准备用来部署 WarpGPT 的端口 |
Use HTPPS | False |
DNS support | True |
添加完新站点后,继续点击上方的 Manage SSL certificates ,接着在出口 IP 的右侧点击 Manage ,再点击 Add certificate :
Type | Domain |
---|---|
Generate Let’s Encrypted certificate | 与刚刚添加的站点域名保持一致(如果是原有的USERNAME.serv00.net ,可以省略此步) |
接着SSH登入,并进入刚刚你新建的域名目录下的 public_html
路径下:
1 |
# 下载二进制文件 |
添加启动脚本:
1 |
cat > start.sh << EOF |
给启动脚本赋权:
1 |
chmod +x start.sh |
配置环境变量:
1 |
cat > .env << EOF |
如果有 redis 需求,可以查阅官方文档:Redis
使用 pm2 管理运行:
1 |
pm2 start bash --name warpgpt -- start.sh |
Coze-discord-proxy
代理 Discord 对话 Coze-Bot ,实现以 API 形式请求 GPT4 模型,提供对话、文生图、图生文、知识库检索等功能。功能不多赘述,详细去源仓库查看。
同样的,我写了一个用于构建 FreeBSD 版本的仓库。在这里感谢论坛用户 Reno 的测试,没有测试人员的测试,也不会有部署的过程记录了。
首先在 Panel 中放行一个端口,接着按照下表 Add a New Website :
Key | Value |
---|---|
Domain | xxx.USERNAME.serv00.net (也可以把原有的USERNAME.serv00.net删掉后重新添加) |
Website Type | proxy |
Proxy Target | localhost |
Proxy URL | 留空 |
Proxy port | 你准备用来部署 Coze-discord-proxy 的端口 |
Use HTPPS | False |
DNS support | True |
添加完新站点后,继续点击上方的 Manage SSL certificates ,接着在出口 IP 的右侧点击 Manage ,再点击 Add certificate :
Type | Domain |
---|---|
Generate Let’s Encrypted certificate | 与刚刚添加的站点域名保持一致(如果是原有的USERNAME.serv00.net ,可以省略此步) |
接着SSH登入,并进入刚刚你新建的域名目录下的 public_html
路径下:
1 |
# 下载二进制文件 |
添加启动脚本:
1 |
cat > start.sh << EOF |
给启动脚本赋权:
1 |
chmod +x coze-discord-proxy |
添加多机器人配置文件:
1 |
mkdir -p app/coze-discord-proxy/data/config |
然后回到 Panel 中,进入File manager选项卡,进入 bot_config.json
所在路径,右键点击它,选择View/Edit > Source Editor,进行编辑:
1 |
[ |
使用 pm2 管理运行:
1 |
pm2 start bash --name coze-discord-proxy -- start.sh |
Memos
一款开源、轻量级的笔记服务。轻松捕捉并分享您的精彩想法。
这个仓库比较难受的是,其在源码的这个位置强制要求其 gRPC 服务的端口为 Memos 监听端口+1,故这个应用需要占用两个端口,而且必须是两个连续的端口。
同样的,我写了一个用于构建 FreeBSD 版本的仓库。
首先在 Panel 中放行两个相邻的端口,接着按照下表 Add a New Website :
Key | Value |
---|---|
Domain | xxx.USERNAME.serv00.net (也可以把原有的USERNAME.serv00.net删掉后重新添加) |
Website Type | proxy |
Proxy Target | localhost |
Proxy URL | 留空 |
Proxy port | 刚刚放行的两个相邻的端口中小的那一个 |
Use HTPPS | False |
DNS support | True |
添加完新站点后,继续点击上方的 Manage SSL certificates ,接着在出口 IP 的右侧点击 Manage ,再点击 Add certificate :
Type | Domain |
---|---|
Generate Let’s Encrypted certificate | 与刚刚添加的站点域名保持一致(如果是原有的USERNAME.serv00.net ,可以省略此步) |
接着SSH登入,并进入刚刚你新建的域名目录下的 public_html
路径下:
1 |
API_URL="https://api.github.com/repos/k0baya/memos-binary/releases/latest" |
关于运行,有两种方式进行:
① SQLite
如果选择使用 SQLite 作为数据库运行,则可以直接运行:
1 |
# 假定你的数据文件打算存储在 /home/username/domains/xxx.USERNAME.serv00.net/public_html/data |
② 外接 MySQL / PostgreSQL
你可以使用面板自带的 MySQL / PostgreSQL 新建数据库,或者使用其他平台提供的远程数据库:
1 |
# 假定你的数据文件打算存储在 /home/username/domains/xxx.USERNAME.serv00.net/public_html/data |
Frps
内网穿透嘛,懂的都懂,这里只做服务端的部署记录,客户端可以查看 Frp 的官方文档自行配置。感谢群友的率先测试:youyi
首先在 Panel 中放行两个端口,接着按照下表 Add a New Website :
Key | Value |
---|---|
Domain | xxx.USERNAME.serv00.net (也可以把原有的USERNAME.serv00.net删掉后重新添加) |
Website Type | proxy |
Proxy Target | localhost |
Proxy URL | 留空 |
Proxy port | 你准备用来映射转发内网服务的端口 |
Use HTPPS | False |
DNS support | True |
添加完新站点后,继续点击上方的 Manage SSL certificates ,接着在出口 IP 的右侧点击 Manage ,再点击 Add certificate :
Type | Domain |
---|---|
Generate Let’s Encrypted certificate | 与刚刚添加的站点域名保持一致(如果是原有的USERNAME.serv00.net ,可以省略此步) |
同样的,你可以设置多个域名使用 Proxy 指向同一个端口,在 Frpc 客户端配置中使用域名分发不同的服务。具体可以查阅官方文档。
接着SSH登入,并进入刚刚你新建的域名目录下的 public_html
路径下
1 |
release_info=$(curl -s https://api.github.com/repos/fatedier/frp/releases/latest) |
接着编辑配置文件:
1 |
# 按照自己的实际情况和需求进行配置,这里只做最简单的http转发配置示例 |
运行:
1 |
pm2 start ./frps -- -c frps.toml |
客户端配置示例:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15 serverAddr = "x.x.x.x"
serverPort = Frps 的监听端口
auth.token = "密码"
[[proxies]]
name = "web"
type = "http"
localPort = 80
customDomains = ["www.yourdomain.com"]
[[proxies]]
name = "web2"
type = "http"
localPort = 8080
customDomains = ["www.yourdomain2.com"]
Rclone
Rclone 是一款管理云存储文件的命令行程序。它功能丰富,可替代云供应商的网络存储界面。超过 70 种云存储产品支持 Rclone,包括 S3 对象存储、企业和消费者文件存储服务以及标准传输协议。
具体用法与配置请查阅其官方文档。
如果你需要使用 Rclone 的 web ui ,你可以按照前文所述的大多数应用一样,先放行端口,添加域名,申请好 SSL 证书,并进入其目录下的 public_html
路径下再进行程序本体的下载部署。
下载最新版 Rclone:
1 |
release_info=$(curl -s https://api.github.com/repos/rclone/rclone/releases/latest) |
经我测试,目前 v1.63.1 之后的版本的 FreeBSD 版的构建都有无法识别 mount
命令的问题,在我查阅其 issue —— #7432 、 #5843 后,确定这个 bug 已经好几个月没有修复了。所以我建议在此 bug 修复前,使用 v1.63.1 版本。
下载 v1.63.1 版本 Rclone :
1 |
curl -L https://github.com/rclone/rclone/releases/download/v1.63.1/rclone-v1.63.1-freebsd-amd64.zip -o rclone-freebsd-amd64.zip |
配置 Rclone 的存储:
1 |
./rclone config |
启动 web ui:
1 ./rclone rcd --rc-web-gui --rc-user 用户名 --rc-pass 密码 --rc-addr :端口pm2 管理 web ui:
1 pm2 start ./rclone -- rcd --rc-web-gui --rc-user 用户名 --rc-pass 密码 --rc-addr :端口
Cloudreve
Cloudreve 可助你即刻构建出兼备自用或公用的网盘服务,通过多种存储策略的支持、虚拟文件系统等特性实现灵活的文件管理体验。
同样的,我编写了一个用于自动化构建 FreeBSD 版本的 Cloudreve 的仓库:k0baya/cloudreve-freebsd 前后端分离构建,前端静态文件在 Cloudreve 本体同路径下的 static
文件夹内。
首先在 Panel 中放行一个端口,接着按照下表 Add a New Website :
Key | Value |
---|---|
Domain | xxx.USERNAME.serv00.net (也可以把原有的USERNAME.serv00.net删掉后重新添加) |
Website Type | proxy |
Proxy Target | localhost |
Proxy URL | 留空 |
Proxy port | 你准备用来部署 Cloudreve 的端口 |
Use HTPPS | False |
DNS support | True |
添加完新站点后,继续点击上方的 Manage SSL certificates ,接着在出口 IP 的右侧点击 Manage ,再点击 Add certificate :
Type | Domain |
---|---|
Generate Let’s Encrypted certificate | 与刚刚添加的站点域名保持一致(如果是原有的USERNAME.serv00.net ,可以省略此步) |
接着SSH登入,并进入刚刚你新建的域名目录下的 public_html
路径下:
1 |
release_info=$(curl -s https://api.github.com/repos/k0baya/cloudreve-freebsd/releases/latest) |
Cloudreve 在首次启动时,会创建初始管理员账号,请注意保管管理员密码,此密码只会在首次启动时出现。如果您忘记初始管理员密码,需要删除同级目录下的 cloudreve.db
,重新启动主程序以初始化新的管理员账户。
Cloudreve 默认会监听 5212
端口。首次启动时,Cloudreve 会在同级目录下创建名为 conf.ini
的配置文件,你可以修改此文件进行一些参数的配置(比如端口),保存后需要重新启动 Cloudreve 生效。
一个完整的配置文件示例如下:
1 |
[System] |
你可以使用 vim
或者 Panel 中的 File manager 选项卡,进入 conf.ini
所在路径路径,右键点击,选择 View/Edit > Source Editor ,进行编辑。
修改完配置文件后,测试启动:
1 |
./cloudreve |
使用 pm2 管理:
1 |
pm2 start ./cloudreve |
PanIndex
一个简易的网盘目录列表。
同样的,我编写了一个用于自动化构建 FreeBSD 版本的 PanIndex 的仓库:k0baya/panindex-freebsd。
后台地址(默认):
http://ip:port/admin
默认账号:admin
默认密码:PanIndex
首先在 Panel 中放行一个端口,接着按照下表 Add a New Website :
Key | Value |
---|---|
Domain | xxx.USERNAME.serv00.net (也可以把原有的USERNAME.serv00.net删掉后重新添加) |
Website Type | proxy |
Proxy Target | localhost |
Proxy URL | 留空 |
Proxy port | 你准备用来部署 PanIndex 的端口 |
Use HTPPS | False |
DNS support | True |
添加完新站点后,继续点击上方的 Manage SSL certificates ,接着在出口 IP 的右侧点击 Manage ,再点击 Add certificate :
Type | Domain |
---|---|
Generate Let’s Encrypted certificate | 与刚刚添加的站点域名保持一致(如果是原有的USERNAME.serv00.net ,可以省略此步) |
接着SSH登入,并进入刚刚你新建的域名目录下的 public_html
路径下:
1 |
release_info=$(curl -s https://api.github.com/repos/k0baya/panindex-freebsd/releases/latest) |
创建配置文件:
1 |
cat > config.json << EOF |
数据库支持 sqlite (默认)、mysql、postgres ,如果需要接入 MySQL 或者 PostgreSQL ,请写成数据库链接的方式填入 dsn 。注意,如果是 Serv00 自带的 PostgreSQL ,请在数据库链接最末加上
?sslmode=disable
以禁用 SSL 连接。
编写好配置文件后,测试运行:
1 |
./panindex -c=config.json |
使用 pm2 管理:
1 |
pm2 start ./panindex -- -c=config.json |
Artalk
似乎有几个群友在用这个,为方便查阅统一收录在本文,具体内容可以去群友的博客查看:
点击图片进入
收尾工作
听说 Serv00 会不定时重启机器,所以我们把 pm2 添加开机自启,可以保证每次重启都能由 pm2 调动 Alist 和 Cloudflared 。而且 Serv00 每三个月内必须要有一次登录面板或者 SSH 连接,不然会删号,也可以通过一个脚本解决问题,接下来我会详细说明。
自动续期
可以用青龙面板的自动任务定期登录SSH解决。在青龙面板中添加Linux依赖 sshpass
,然后添加定时任务:名称随意,命令/脚本 sshpass -p '密码' ssh -o StrictHostKeyChecking=no -o UserKnownHostsFile=/dev/null -tt 用户名@地址 "exit"
,定时规则 1 1 1 * *
。这样就会每个月自动ssh连接一次,实现续期。
你还可以使用自身 SSH 自身的方式进行自动续期,操作如下:
进入一个自己喜欢的路径,使用
cat
命令新建auto-renew.sh
脚本:
1
2
3
4
5
6
7
8 cat > auto-renew.sh << EOF
#!/bin/bash
while true; do
sshpass -p '密码' ssh -o StrictHostKeyChecking=no -o UserKnownHostsFile=/dev/null -tt 用户名@地址 "exit" &
sleep 259200 #30天为259200秒
done
EOF记得把其中的密码、用户名、ssh的地址修改为你自己的。
给
auto-renew.sh
添加可执行权限:
1 chmod +x auto-renew.sh使用pm2启动:
1 pm2 start ./auto-renew.sh这样就会每隔一个月自动执行一次SSH连接,自己SSH自己进行续期。
上述自动续期脚本,在当时写的时候,犯了两个错误:
第一是时间写错了,30 天不是 259200 秒,是 2592000 秒,经群友发现后,就成了一个防伪标志,因为本文在网络上大量被复制粘贴却不标明出处,让太多人赚了流量却不知道真正码字的是谁。抄袭可耻,这样的抄袭行为只会让真正有能力创作的人失去继续创作的热情。
第二是不应该在脚本内写成
while
循环配合sleep
定时,这样导致大量的sleep
进程把进程数占满而出现异常。正确的做法应该是:
使用下述命令新建auto_renew.sh
脚本:
1
2
3
4
5 cat > auto_renew.sh << EOF
#!/bin/bash
sshpass -p '密码' ssh -o StrictHostKeyChecking=no -o UserKnownHostsFile=/dev/null -tt 用户名@地址 "exit" &
EOF记得把其中的密码、用户名、ssh的地址修改为你自己的。
给
auto_renew.sh
添加可执行权限:
1 chmod +x auto_renew.sh再去 Panel 中找到 Cron jobs 选项卡,使用 Add cron job 功能添加任务,Specify time 选择 Monthly,Form type 选择 Advanced。Command 写
auto_renew.sh
脚本文件的绝对路径,如/home/username/auto_renew.sh >/dev/null 2>&1
即可。
自动启动
听说 Serv00 的主机会不定时重启,所以需要添加自启任务。
在 Panel 中找到 Cron jobs 选项卡,使用 Add cron job 功能添加任务,Specify time 选择 After reboot,即为重启后运行。Form type 选择 Advanced,Command 写:
1 |
/home/你的用户名/.npm-global/bin/pm2 resurrect >/dev/null 2>&1 && /home/你的用户名/.npm-global/bin/pm2 restart all >/dev/null 2>&1 |
记得把你的用户名改为你的用户名
添加完之后,在 SSH 窗口保存 pm2 的当前任务列表快照:
1 |
pm2 save |
这样每次 serv00 不定时重启任务时,都能自动调用 pm2 读取保存的任务列表快照,恢复任务列表。如果在保存了任务列表快照后又改变了任务 pm2 的任务列表,需要重新执行 pm2 save
以更新任务列表。
检测启动情况
由于自从 S2 开始的新的 Server 推出后屡屡出现使用 Cron Job 的 After reboot 无法恢复任务列表的情况,而过了好几个月也并没有人找到令人满意的解决方案,循环监控网页状态码并在出错时尝试拉起任务是可行的,只可惜我只看到了 Python 脚本,而此等简单的功能在我看来实在没必要使用 Python ,毕竟如果要在没有 Python 环境的情况下运行又成了一种麻烦,所以我决定通过 Shell 实现此功能。
1 |
#!/bin/bash |
在脚本开头处填好所有的环境变量即可使用:
变量名 | 是否必须 | 备注 |
---|---|---|
USERNAME | 是 | Serv00 的账户用户名 |
PASSWORD | 是 | Serv00 的账户密码 |
SSH_ADDRESS | 是 | Serv00 的账户 SSH 连接的地址(如s4.serv00.com ) |
SERVER_ADDRESS | 是 | 需要检测的 Web 服务地址(如https://xxx.username.serv00.net ) |
SMTP_SERVER_ADDRESS | 否 | 发送通知邮件的 SMTP 服务器地址(如mail4.serv00.com 、smtp.163.com ) |
SMTP_SERVER_PORT | 否 | 发送通知邮件的 SMTP 服务器端口,必须使用 SSL(如465 、995 ) |
SMTP_EMAIL | 否 | 用于发送通知邮件的邮箱 |
SMTP_PASSWORD | 否 | 用于发送通知邮件的邮箱的密码或秘钥 |
TARGET_EMAIL | 否 | 用于接收通知邮件的邮箱 |
在你的用户目录下任意路径新建一个名为 check_health.sh
的文件,把上述脚本填好环境变量后粘贴进去,并在 Console 中使用 chmod +x check_health.sh
命令为脚本添加可执行权限。
再去 Panel 中找到 Cron jobs 选项卡,使用 Add cron job 功能添加任务,Specify time 选择 Special manually,Form type 选择 Advanced, 然后把下方的 Minute、Hour、Day of month、Month、Day of week 都改成 Every ,然后在 Minute 后填入 5(即每 5 分钟一次),其他的都填 1。Command 写 check_health.sh
脚本文件的绝对路径,如 /home/username/check_health.sh >/dev/null 2>&1
即可。你也可以根据你的需求自由修改定时。
还有一个加入了循环的版本,有需求的可以移植到其他服务使用:
1 |
# 各功能函数与前文一致,主函数加入循环,只展示主函数部分 |
常用指令
1 |
# Enables the ability to run your own software |
欢迎进群讨论,一起学习探讨:受虐滑稽