Gitlab结合阿里云ECS进行弹性伸缩构建

Gitlab结合阿里云ECS进行弹性伸缩构建

问题背景

Gitlab 默认支持亚马逊、微软云、谷歌云的弹性伸缩构建,如果想使用阿里云实现弹性伸缩构建,可以考虑使用官方提供的基于k8s的弹性伸缩构建,但是大部分情况下单独配置一个集群有些麻烦。

官方提供了一个Custom Runner,可以借助shell脚本实现自定义逻辑。那么我们就可以在脚本中利用阿里云的sdk动态创建ECS实例来实现弹性伸缩构建。经过简单的测试,利用现成的云盘镜像创建一个实例大概10秒左右,速度可以接受。

所以打算使用这个方案来实现弹性伸缩构建,即每次构建通过特定的镜像ID创建一个阿里云ECS实例,执行构建脚本以后再销毁掉。

脚本原理

脚本构成

整个Custom Runner 分为4个脚本

  • config_exec 用来设置构建目录、环境变量之类的

  • prepare_exec 用来准备脚本执行环境,我们用这个脚本创建ECS实例

    注意:这个脚本每个Job都会运行

  • run_exec 用来运行构建逻辑,我们用这个脚本执行.gitlab-ci.yml中的script,Gitlab调用脚本的方式如下

    bash 复制代码
    /path/to/run_exec.sh /path/to/tmp/script1 prepare_script
  • cleanup_exec 用来清理构建环境,我们用这个脚本释放ECS实例

生命周期

run_exec作为主要执行的脚本,其中有一些生命周期事件需要我们实现

  1. prepare_script 用于查看debug信息
  2. get_sources 用于拉取仓库代码,我们在这个生命周期拉取代码
  3. restore_cache 用于恢复缓存
  4. download_artifacts 用于下载制品
  5. step_* Gitlab自动生成
  6. build_script 用于执行job里面的script,我们在这个生命周期执行自定义的构建脚本
  7. step_* Gitlab自动生成
  8. after_script 用于执行job里面的after_script
  9. archive_cache 或者 archive_cache_on_failure 用于归档缓存
  10. upload_artifacts_on_success 或者 upload_artifacts_on_failure 用于上传制品
  11. cleanup_file_variables 用于删除文件类型的变量

其他

关于脚本的错误处理、返回值、一些具体的例子这里不展开了,可以直接去官方文档查看

脚本源码

代码已经发布到github:项目地址

配置项

Runner配置项

登录镜像需要的密钥、阿里云CLI所需的AK、缓存目录等配置,可以提取到env文件中单独设置

作业配置项

将镜像ID、缓存目录通过特定的环境变量指定,这样不同的项目可以通过配置改变缓存行为,比如Gradle需要缓存~/.gradle目录,nodejs需要缓存~/.npm目录

如何配置.gitlab-ci.yml

yml 复制代码
stages:
- build

build:
    stage: build
    environment:
    name: $CI_COMMIT_BRANCH
    variables:
        CACHE_DIRS: "/root/.npm/,其他目录"
        IMAGE_ID: "阿里云镜像ID"
        INSTANCE_TYPE: "阿里云实例规格(如:ecs.c6.2xlarge)"
        script:
            - |
            # 自定义的构建脚本,如:
            bash deploy/make_product.sh
            bash deploy/k8s_update.sh

优化项

通过缓存目录提高构建速度

可以使用ossfs2.0进行构建缓存的挂载,成本低廉

通过内网拉取代码提高构建速度

如果构建用的服务器和Gitlab在同一个网络,可以对整体构建速度有提升,并且节约网络流量费用

通过内网推送代码提高部署速度

如果构建用的服务器和制品库在同一个网络,可以显著提高部署速度,并且节约网络流量费用

作者:脆皮猪

授权:著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

相关推荐
一战成名99618 小时前
AI 模型持续集成流水线:CANN 支持的 DevOps 最佳实践
人工智能·ci/cd·devops
我会一直在的18 小时前
Devps持续集成
git·ci/cd
池央2 天前
CANN oam-tools 诊断体系深度解析:自动化信息采集、AI Core 异常解析与 CI/CD 流水线集成策略
人工智能·ci/cd·自动化
池央3 天前
CANN GE 深度解析:图编译器的核心优化策略、执行流调度与模型下沉技术原理
人工智能·ci/cd·自动化
3GPP仿真实验室3 天前
【Matlab源码】6G候选波形:OFDM-IM 增强仿真平台 DM、CI
开发语言·matlab·ci/cd
小Tomkk3 天前
数据库 变更和版本控制管理工具 --Bytebase 安装部署(linux 安装篇)
linux·运维·数据库·ci/cd·bytebase
_运维那些事儿3 天前
VM环境的CI/CD
linux·运维·网络·阿里云·ci/cd·docker·云计算
木童6624 天前
Ruo-Yi 项目 CI/CD 详细部署文档
ci/cd
爬山算法4 天前
Hibernate(85)如何在持续集成/持续部署(CI/CD)中使用Hibernate?
java·ci/cd·hibernate
吹牛不交税4 天前
gitea安装windows并实现CICD持续集成部署
ci/cd·gitea