博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Gitlab持续集成-(.gitlab-ci.yml)
阅读量:6300 次
发布时间:2019-06-22

本文共 4797 字,大约阅读时间需要 15 分钟。

从7.12版本开始,GitLab CI使用YAML文件(.gitlab-ci.yml)来管理项目配置。该文件存放于项目仓库的根目录,它定义该项目如何构建。

stages

stages用来定义可以被job调用的stages。stages的规范允许有灵活的多级pipelines。stages中元素的顺序决定了对应job的执行顺序:

  • 相同stage的job是并行执行的;
  • 下一个stage的job在前一个stage的job成功完成后才开始执行;
  • 如果.gitlab-ci.yml中没有定义stages,那么stages默认定义为build、test和deploy;
  • 如果一个job没有指定stage,那么这个任务会分配到test stage。

variables

variables用来定义变量,全局变量作用于所有job,也可以在指定的job中定义变量(优先级高于全局变量)

如果在job中想禁用全局定义的变量,可通过variables: {}定义一个空的哈希值。

variables 变量值
CI_JOB_NAME 对应的job_name
GIT_STRATEGY 指定git获取代码的方式(clone,fetch,none)

jobs

jobs用来定义了一组作业,其中必须包含script语句。

job.stage(默认:test

job中指定的stage必须是stages中存在的元素

job.tags

指定该job所允许运行的Runner,必须在注册Runner时设置Runner的tag

job.allow_failure

用于指定该job允许执行失败,则如果执行失败也不会影响下一个stage的执行。

job.script

script是job中必须指定的语句,指定Runner所要执行的命令

job.before_script、job.after_script

指定script执行前/后所执行的命令,也可定义在全局模式,则在所有job中的script执行前/后都会执行。

job.artifacts

用于指定job执行成功后,将会被发送到Gitlab中的文件,且默认情况下job之间会根据stage的优先级自动下载之前所有stage中的artifacts。

  • artifacts.paths:必选
  • artifacts.name:指定artifact的名称,同时Gitlab上下载的文件名即为artifact_name.zip
  • artifacts.when:指定artifact上传到Gitlab的条件(on_success[默认],on_failure,always)
  • artifacts.expire_in:指定artifact的过期时间(默认为30天),使用keep可永久保存

job.dependencies

dependencies用于在不同的job之间指定在不同的job之间传递artifacts,dependencies: []可禁止该job下载artifacts

job.only、job.except

onlyexcept是两个参数用分支策略来限制jobs构建

  • onlyexcept可同时使用。如果在一个job配置中同时存在,则同时有效;
  • onlyexcept可以使用正则表达式;
  • onlyexcept允许使用特殊的关键字:branchestagstriggers

job.environment

environment用于定义job部署到指定的运行环境中。

  • environment.name:必选,指定environment名称
  • environment.url:可选,指定environment对应的URL,将在指定的environment页面中添加一个链接按钮指向该URL

特殊的YAML特性

<span id = "jump"> Hidden keys(jobs)</span>

如果想临时disable某个job,不必注释整个job定义的行,只需在job name前加一个.即可

.compile_centos:  stage: build_centos  tags:    - centos  script:    - echo "##### build library"

Anchors

锚点可用于在文件中复制或继承配置,一般与提供的job模版搭配使用。

.job_template: &job_definition  #job中定义一个anchor:job_definition  image: ruby:2.1  services:    - postgres    - redistest1:  <<: *job_definition           #合并anchor:job_definition中的模版内容  script:    - test1 projecttest2:  <<: *job_definition  script:    - test2 project

最终实现的效果如下:

.job_template:  image: ruby:2.1  services:    - postgres    - redistest1:  image: ruby:2.1  services:    - postgres    - redis  script:    - test1 projecttest2:  image: ruby:2.1  services:    - postgres    - redis  script:    - test2 project

Skipping jobs

如果你的commit信息中包含[ci skip]或者[skip ci],不论大小写,那么这个commit将会创建但是jobs也会跳过。


example:

以下示例为编译nginx的上传模块nginx-upload并测试验证上传功能,验证成功后将自动将编译好的文件打包通过curl上传到指定的文件服务器。其中只有在非master的branches中提交代码才会执行build和test的stage,只有在打tag后才会执行deploy,且需要手动在gitlab上执行。

variables:  DIR: nginx  TOPNODE: package.function: &function |  function build() {    echo "execute function:build"    chmod +x auto/configure    sh build.sh  }  function changelog() {    echo "execute function:changelog"    git log --graph -n 3  --name-status --pretty="%h -[%cd] - <%an> %s" > CHANGELOG  }  function test() {    echo "execute function:test"    sudo \cp modules/nginx-upload-module-master/nginx.conf /etc/nginx/nginx.conf    sudo sed -i '/error_log/,/working_directory/d' /etc/nginx/nginx.conf    if [ -f /run/nginx.pid ];then sudo nginx -s reload;else sudo nginx;fi    sudo rm -rf /tmp/{0,1,2,3,4,5,6,7,8,9} && sudo mkdir /tmp/{0,1,2,3,4,5,6,7,8,9} && sudo chown -R nginx. /tmp/{0,1,2,3,4,5,6,7,8,9}    sudo echo nginx_upload > test && curl -F "filename=@test" http://localhost/upload    sudo find /tmp/{0,1,2,3,4,5,6,7,8,9} -type f -exec grep nginx_upload {} \;   }  function artifacts() {    echo "execute function:artifacts"    URL="https://xxx.com/upload?dir=${DIR}/${VERSION}&override=1&topNode=${TOPNODE}"    echo "push the artifacts:nginx_${VERSION}.tar.gz to $URL"    tar zcf /tmp/nginx_${VERSION}.tar.gz --exclude=".git*" --exclude=build .    curl -F "filename=@/tmp/${DIR}_${VERSION}.tar.gz" "$URL"    echo "push the CHANGELOG to $URL"    curl -F "filename=@CHANGELOG" "$URL"  }  function deploy() {    echo "execute function:deploy"  }  function clean() {    echo "execute function:clean"    if [ -f /run/nginx.pid ];then sudo kill `cat /run/nginx.pid`;fi    sudo rm -rf /tmp/{0,1,2,3,4,5,6,7,8,9} /tmp/nginx_${version}.tar.gz  }#########only the section above need to be modify #################before_script:  - VERSION=`head -n1 version`  - *functionstages:  - build  - test  - deploybuild:  stage: build  only:    - branches  except:    - master  script:    - build    - changelogtest:  stage: test  variables:    GIT_STRATEGY: none  only:    - branches  except:    - master  script:    - test    - artifacts    - clean.job_template: &deploy_template  stage: deploy  variables:    GIT_STRATEGY: none  only:    - tags  script:    - deploy    - delete  when: manualstaging:  <<: *deploy_template  environment:    name: stagingproduction:  <<: *deploy_template  environment:    name: production

转载地址:http://uqrta.baihongyu.com/

你可能感兴趣的文章
AWS EC2 Run Command特性新增多重云脚本
查看>>
vue.js轻松搞定后台管理项目
查看>>
前端开发者的 Chrome extensions/apps
查看>>
Gilt如何将微服务部署到AWS环境,介绍ION-Roller
查看>>
Linux之父为过去的言行道歉,宣布离开社区反思
查看>>
apache 2.4.7 如何修改端口。
查看>>
1027问题汇总
查看>>
对象的深复制
查看>>
PHP 实现用户注册登录功能
查看>>
基于Laravel的API服务端架构代码
查看>>
[贰]Flask web开发:程序的基本结构
查看>>
前端手册
查看>>
148. Sort List
查看>>
Design Patterns - Interpreter Pattern(译)
查看>>
JavaScript类型系统详解
查看>>
git 提交vendor目录至项目
查看>>
touch事件小结
查看>>
Let’s configure DRBD on Ubuntu Server 14.04
查看>>
SQLAlchemy入门(一)
查看>>
CoreData初次实践(一)
查看>>