随着微服务越写越多,程序发布就成了一个麻烦事,所以写了一个部署工具 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

添加目标服务器


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

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

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

添加程序


在“程序部署列表”页面,点击【新部署程序】按钮,添加你要部署的程序。

例如,我现在要把一个开源的微服务网关,部署到我的服务器上,可以如下配置:









编译并发布


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

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

安装nodejs也可编译前端项目

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

源码地址


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

开源一套快速部署程序的工具(CI/CD)的更多相关文章

  1. docker 快速部署ES集群 spark集群

    1) 拉下来 ES集群  spark集群 两套快速部署环境, 并只用docker跑起来,并保存到私库. 2)弄清楚怎么样打包 linux镜像(或者说制作). 3)试着改一下,让它们跑在集群里面. 4) ...

  2. 使用kubeadm快速部署一套K8S集群

    一.Kubernetes概述 1.1 Kubernetes是什么 Kubernetes是Google在2014年开源的一个容器集群管理系统,Kubernetes简称K8S. K8S用于容器化应用程序的 ...

  3. 如何快速部署国人开源的 Java 博客系统 Tale

    除了闷头专研技术之外,程序员还需要不断地写作进行技术积累,写博客是其中最重要的方式之一.商业博客平台不少,但是更符合程序员背景的方案,是自己开发一个博客平台或者使用开源的博客平台. 开源的博客平台多如 ...

  4. 【干货】快速部署微软开源GPU管理利器: OpenPAI

    [干货]快速部署微软开源GPU管理利器: OpenPAI 介绍 不管是机器学习的老手,还是入门的新人,都应该装备上尽可能强大的算力.除此之外,还要压榨出硬件的所有潜力来加快模型训练.OpenPAI作为 ...

  5. 一键快速部署CodeBlocks的EGE图形库工具

    大一下学期,学完了c语言的基本内容, 也就开始开发项目了,此时一个图形界面就比较重要了,c语言中不提供图形界面,一般这些是用的其它开发的图形库,如 Easyx .ege等. 本文就提供 Codeblo ...

  6. eas之EAS手工打包及快速部署工具

    EAS手工打包及快速部署工具:jar包的命名是项目名就好了.   1. 在eas的工作空间下:E:\Easworkspace\Project_0 有classes和deployed_metas这两个文 ...

  7. IDEA工具下Mybaties框架快速入门程序

    本篇文章介绍在IDEA工具下mybatis快速入门程序分为以下五步 ​ 1 添加依赖包 ​ 2 编写pojo对象 ​ 3 编写映射文件 ​ 4 编写核心配置文件 ​ 5 测试框架 详细如下 建立Mod ...

  8. Android 开源控件与常用开发框架开发工具类

    Android的加载动画AVLoadingIndicatorView 项目地址: https://github.com/81813780/AVLoadingIndicatorView 首先,在 bui ...

  9. 使用Rancher的RKE快速部署Kubernetes集群

    简要说明: 本文共涉及3台Ubuntu机器,1台RKE部署机器(192.168.3.161),2台Kubernetes集群机器(3.162和3.163). 先在Windows机器上,将rke_linu ...

  10. 私活利器,docker快速部署node.js应用

    http://cnodejs.org/topic/53f494d9bbdaa79d519c9a4a 最近研究了几天docker的快速部署,感觉很有新意,非常轻量级和方便,打算在公司推广一下,解放运维, ...

随机推荐

  1. GIT保存记录原理之commit对象

    GIT 中提交对象非常的重要,我们通过它记录代码提交过程.进行文件保存.回退等操作,那么它是怎样帮助我们记录这些信息的呢?其实就是都保存在项目根目录的 .git 文件夹中. 新建空项目 ```gitD ...

  2. 处理css/js兼容性的工具之超重要的browserslist

    这篇 webpack处理css资源 文章中使用到的工具 browserslist 对于兼容性处理来说非常重要!这一篇来仔细说说. 查询兼容性 不同浏览器对于 css / js 的属性可能存在兼容性,具 ...

  3. 新一代开源流数据湖平台Apache Paimon入门实操-下

    @ 目录 实战 写表 插入和覆盖数据 更新数据 删除数据 Merge Into 查询表 批量查询 时间旅行 批量增量查询 流式查询 时间旅行 ConsumerID 查询优化 系统表 表指定系统表 分区 ...

  4. Nginx深入:nginx功能模块、目录结构及配置文件详解

    Nginx功能模块说明 1.Nginx 核心功能模块(Core functionality) Nginx核心功能模块负责Nginx的全局应用,主要对应主配置文件的核心层(Main层)和事件(Event ...

  5. 事务,不只ACID

    1. 什么是事务? 应用在运行时可能会发生数据库.硬件的故障,应用与数据库的网络连接断开或多个客户端端并发修改数据导致预期之外的数据覆盖问题,为了提高应用的可靠性和数据的一致性,事务应运而生. 从概念 ...

  6. 通过替换dll实现后门功能的恶意代码

    通过替换Kernel32.dll来实现的后门功能的恶意代码. 该恶意代码存在一个exe可执行文件和一个dll动态链接库,需要分别进行分析 一.待解决问题 这个恶意代码执行了什么功能? 通过什么方式实现 ...

  7. 使用.NET Jieba.NET 的 PosSegmenter 实现中文分词匹配

    ​ 目录 引言 1. 什么是中文分词 2. Jieba.NET简介 3. PosSegmenter介绍 4. 实现中文分词匹配 4.1 安装Jieba.NET库 4.2 创建PosSegmenter实 ...

  8. Pytorch构建超分辨率模型——常用模块

    Import required libraries: import torch import torch.nn as nn import torch.optim as optim from torch ...

  9. SQL简单使用指南

    SQL简单使用指南 SQL(结构化查询语言)是一种用于管理和操作关系型数据库的标准化语言. 数据库概述 数据库是用于存储和组织数据的结构.它由表(表格)组成,每个表都包含多个列和行.以下是SQL中最常 ...

  10. 【Azure 存储服务】访问Azure Blob File遇见400-Condition Headers not support错误的解决之路

    问题描述 在微软云存储账号的服务中,存储一些静态图片,然后通过App Service访问,但是遇见了400 - condition headers not support 错误. 在单独通过浏览器访问 ...