开源一套快速部署程序的工具(CI/CD)

发布时间 2023-11-16 15:18:14作者: IWing

随着微服务越写越多,程序发布就成了一个麻烦事,所以写了一个部署工具 Vela,只要填写一个git地址、编译命令等简单信息,就能自动完成程序的部署。

Vela 特性:


  • 代码可在任意一台电脑自动完成编译,再自动上传至服务器

  • 可指定程序以Docker容器方式运行

  • 编译命令采用终端运行,理论支持所有命令行命令

  • 可在线编辑程序配置文件,编辑时可选择其他程序的配置文件作为参考

  • 程序更新时会自动备份现有版本,日后可通过备份列表恢复

  • 实时以列表形式展示所有程序的CPU、内存占用情况,并可设置报警线

Vela 构成


Vela 分为两部份:

  • Vela Web

运行在任意一台电脑上,它负责从git地址克隆代码,并执行编译命令;
对外提供 web 管理页面,作为 Vela 的管理入口。

  • Vela Agent

运行在目标服务器上,负责接收 Vela Web 发送过来的程序文件,并打包为 Docker 映像,然后运行该映像。

Vela 下载地址


https://cccscls-my.sharepoint.com/:f:/g/personal/jack_mutc_ca/Et7VbP7sX31EiN-NQkPL0RgBL5RBG15_PyepR5Tx0PaqsQ?e=BTngox

Vela Agent 安装


在目标服务器(Linux)上,下载 VelaAgent.***.zip ,解压后,在目录下运行下面命令安装vela-agent服务:

sudo chmod +x VelaService
sudo ./VelaService

会询问你用什么用户来运行日后部署的程序,你可以输入特点的用户名,或者直接回车,用root用户运行。

服务安装完毕后,运行 systemctl start vela-agent 启动服务。

如果你以后发布的程序需要以Docker容器的方式运行,那么,在此服务器上,还需要安装Docker。

Vela Web 安装


如果你用windows跑vela web,直接运行 VelaWeb.Server.exe 即可,不用参考下面Linux安装步骤。

在编译服务器(Linux)上,下载 VelaWeb.***.zip ,解压后,在目录下运行下面命令安装vela-web服务:

sudo chmod +x VelaService
sudo ./VelaService

会询问你用什么用户来运行该服务,你可以输入特点的用户名,或者直接回车,用root用户运行。

服务安装完毕后,运行 systemctl start vela-web 启动服务。

由于我平时都是部署.net项目和vue前端项目,所以,编译服务器我还会安装.net sdk、nodejs等环境

浏览器访问管理页面


vela-web是一个web服务,通过 http://ip:10001 可以访问它的管理页面,如果要修改它的端口,编辑 /opt/software/vela-web-application/appsettings.json 文件,然后重启服务即可:systemctl restart vela-web

默认管理员用户:admin 密码: admin

image

添加目标服务器


在“服务器列表”页面,点击添加服务器,把你的vela-agent服务器,添加到列表当中。

image

为了安全考虑,一个 vela-agent 服务器,只能被一个 vela-web 绑定,当 vela-agent 被添加到列表后,其他 vela-web 无法和它再绑定。

如果要解除这种绑定关系,需要手动删除 vela-agent 服务器上的 /opt/software/vela-agent-application/data.ClientCertHash文件,并重启服务:systemctl restart vela-agent

添加程序


在“程序部署列表”页面,点击【新部署程序】按钮,添加你要部署的程序。
例如,我现在要把一个开源的微服务网关,部署到我的服务器上,可以如下配置:


image
image
image

编译并发布


在程序列表中,点击表格左边【...】按钮,打开菜单,点击【查看输出日志】按钮

然后会看到打开一个终端页面,点击【立刻发布】按钮,将会看到程序的编译过程。

image

安装nodejs也可编译前端项目

如果你是第一次发布这个程序,编译完成后,它不会立刻运行,会提示你先修改此程序的配置文件,再手动点击【启动】来运行此程序。

源码地址


https://github.com/simpleway2016/vela.git