DevOps-基于Walle的小型持续集成实战二设计

38次阅读

共计 1028 个字符,预计需要花费 3 分钟才能阅读完成。

该文章用于建立一个小型的基于 Walle 的持续集成工具。解决 java,react,angular 项目的编译发布。以便对整个持续集成印象加深。
官方网站:https://walle-web.io/

适用场景

  • 小型服务集群(选用 Docker-Compose ; 不使用 Ansible)
  • 简易构建脚本(选用 Walle)

大规模集群复杂的构建脚本,请学习 Jenkins+Ansible+K8S 等生态

基本思路

  • 使用 Walle 替代 Jenkins 作为构建方案,简化部分操作。但整体的自定义程度会缺失(例如拉去多 git 路径进行统一编译,不支持额外构建参数的传入)
  • 使用 Docker-Compose 作为单机容器编排分方案
  • 环境使用 Gitlab 作为代码管理,Nexus 作为包私有仓库

操作流程

  • 研发环境搭建

    • Gitlab 搭建和基本操作
    • Nexus 搭建(可选)
    • Maven 发布
    • Npm 发布
    • Docker 发布
  • 持续集成

    • Docker 安装和基本操作
    • Walle 安装和基本操作
    • Java 前端项目构建脚本
    • React/Angular 后端项目构建

数据流程

整体流程会串联整个环境上各技术点,最终形成完整的持续集成方案。

  • 发起构建。配置完各环境发布脚本后,则可以使用构建发起进行触发
  • 环境准备。初始化环境参数,例如 antd-pro 的 npm install -g umi 或者npm install -g @tarojs/cli@1.2.11
  • Nxues 拉取环境相关包。包私有仓库会加速 npm install 以及 mvn compile 的下载速度,以及支持私有包的下载
  • 代码检出。根据 branch 的 commit 进行代码检出操作
  • 代码编译。使用 mvn clean compile package -Dmaven.test.skip=true or npm run build 等编译脚本,或者进行预处理(例如解压 node_modules)
  • 远程登录。通过 shh 连接远程服务器
  • 本地版本。压缩内容,并发送到远程服务器上打包。并会在远程环境上存放多次发布的版本,用于回退和切换
  • 服务停用。进行 kill 等操作,停止原本运行的服务
  • 切换启用。通过软连接替换新的本地版本映射到运行路径,再进行服务启动
  • 构建完成。可以进行钉钉或者邮件发送。

以上步骤中,在使用 Walle 的方案下,会集成 [代码检出],[远程登录],[本地版本],[切换启用 - 切换部分],[构建完成] 等步骤,且会自动化删除过程文件

成果展示

项目列表

项目详情

部署管理

部署日志


后记

⚠️ 以上虽然看起来很复杂,实际情况下会更为复杂。容我们一步一步的解决各问题。

正文完
 0