Gitlab CI部署 & 业务中的应用

2018-07-26  本文已影响65人  NowhereToRun

一、持续集成(Continuous Integration)

持续集成是一种软件开发实践,即团队开发成员经常集成他们的工作,通常每个成员每天至少集成一次,也就意味着每天可能会发生多次集成。每次集成都通过自动化的构建(包括编译,发布,自动化测试)来验证,从而尽快地发现集成错误。许多团队发现这个过程可以大大减少集成的问题,让团队能够更快的开发内聚的软件。

简单点说就是一键:合并代码---->安装依赖---->编译---->测试---->发布

也可以简单点,不做服务端打包,只执行一键 测试---->发布

二、GitLab-CI

GitLab-CI就是一套配合GitLab使用的持续集成系统(也有别的配合GitLab使用,比如Jenkins)。GitLab8.0以后的版本是默认集成了GitLab-CI并且默认启用的。

三、GitLab-Runner

GitLab-Runner是配合GitLab-CI进行使用的服务器脚本。
一般地,GitLab里面的每一个工程都会定义一个属于这个工程的软件集成脚本,用来自动化地完成一些软件集成工作。当这个工程的仓库代码发生变动时,比如为某次commit打了tag,CI通知这些Runner把代码更新到本地并执行预定义好的执行脚本。

盗个图,简单明了。

Runner可以分布在不同的主机上,同一个主机上也可以有多个Runner。

Runner类型

  1. Shared Runner:这种Runner(工人)是所有工程都能够用的。只有系统管理员能够创建Shared Runner。

  2. Specific Runner:这种Runner(工人)只能为指定的工程服务。拥有该工程访问权限的人都能够为该工程创建Shared Runner。

四、GitLab-Runner的安装与使用

一、安装

  1. 下载
# Linux x86-64
sudo wget -O /usr/local/bin/gitlab-runner https://gitlab-runner-downloads.s3.amazonaws.com/latest/binaries/gitlab-runner-linux-amd64

# Linux x86
sudo wget -O /usr/local/bin/gitlab-runner https://gitlab-runner-downloads.s3.amazonaws.com/latest/binaries/gitlab-runner-linux-386

# Linux arm
sudo wget -O /usr/local/bin/gitlab-runner https://gitlab-runner-downloads.s3.amazonaws.com/latest/binaries/gitlab-runner-linux-arm
  1. 添加权限
sudo chmod +x /usr/local/bin/gitlab-runner
  1. 运行(我们直接使用了root用户)
sudo gitlab-runner install --user=root --working-directory=/data1/cideploy/
sudo gitlab-runner start

二、注册

  1. 执行,然后按照提示依次输入就完事了。 2~7 都是

    sudo gitlab-runner register
    
    
  2. 输入你的gitlab主页的地址:

    Please enter the gitlab-ci coordinator URL (e.g. https://gitlab.com )
    https://gitlab.weibo.cn/
    
    
  3. 输入gitlab分配给这个runner的token

    Please enter the gitlab-ci token for this runner
    xxx // token
    
    
  4. 这个runner的描述:

    Please enter the gitlab-ci description for this runner
    [hostame] my-runner
    
    
  5. 输入runner的tag,这个是区分runner的关键:

    Please enter the gitlab-ci tags for this runner (comma separated):
    my-tag,another-tag
    
    
  6. 输入执行器,有很多种,比如我们的就是shell:

    Please enter the executor: ssh, docker+machine, docker-ssh+machine, kubernetes, docker, parallels, virtualbox, docker-ssh, shell:
    shell
    
    
  7. 可能还有别的设置,根据runner的版本不同,取默认值就行了。

Whether to run untagged builds [true/false]:
[false]:
Whether to lock the Runner to current project [true/false]:
[true]: false

启动
gitlab-runner run

好了,回去刷新gitlab ci的页面,可以看到这个runner已经启动起来了。

五、GitLab-Runner一些配置

配置文件位于(root用户安装)
/etc/gitlab-runner/config.toml
非root用户~/.gitlab-runner/config.toml(我没试,看网上别人说的)

如果有多个runner,配置都位于这个位置,其中可能需要手动配置的是runner的工作区
添加这个字段即可builds_dir="你的路径" 可参考下图


CI-Runner虽然只是一个运行时的脚本,但是为了严格控制上线质量,检测可能的异常行为,我们将他的生命周期定义为下图所示,每个公司业务场景可能不一致,下面是我们的实践:

生命周期
业务使用TS面向对象设计,使用TS的优势不言而喻,强类型检测,避免了很多低级错误;代码可读性强,后期维护方便。
CIContext贯穿生命周期整个流程,想获取任何的配置,直接取用即可,想要添加上线资源,像webpack一样把资源按配置放在Assets中即可完成上线。
在每个生命周期的开始和结束都有插件的介入,例如beforeDeployafterDeploy,插件化的设计可以让CI的可扩展性变强。例如我想多上线一份资源,或者想多添加一层检查,直接添加一个或两个插件,在对应的deforeDeploybeforeCheck插件运行时做处理即可。
每家的CI业务场景可能都不一致,这里只是我们的一个思路,定义明确的生命周期可以让业务变得易于维护和扩展。

Over。

相关链接

CI的环境变量
CI注册runner
runner安装

上一篇下一篇

猜你喜欢

热点阅读