建木(Jianmu)----建木系统中的内置节点
作者:redrose2100   类别:    日期:2022-05-11 16:29:46    阅读:1169 次   消耗积分:0 分

1 建木中节点的理解

在建木系统中,节点可以理解为一个步骤,比如单元测试、编译、发布、测试、部署等步骤,每个步骤就可以理解为一个节点,因为每个步骤做的事不同,因此节点也是不同的,但是在建木中,将节点划分为内置节点和自定义节点,内置节点包括开始节点、结束节点、shell节点、网关节点,他们的作用分别如下

  • 开始节点:标志流水线的开始
  • 结束节点:标志流水线的结束
  • shell节点:即可以执行shell命令的docker容器
  • 网关节点:即当遇到分支的时候决定写一个步骤使用哪个节点的节点

2 开始节点的定义

  1. start:
  2. targets:
  3. - test_step
  4. type: start

其中:

  • targets:表示下一步骤要执行的节点,比如这里是test_step,当然这里也可以是多个,因此是列表的形式
  • type:类型必须是start

3 结束节点的定义

  1. end:
  2. sources:
  3. - deploy
  4. type: end

其中:

  • sources:表示上一步骤执行的节点,也可以是多个节点,因此也是列表的形式,比如这里是deploy节点
  • type:类型必须是end

4 shell-node节点定义

  1. image: 指定镜像,这里镜像是指docker镜像,即只要在dockerhub上存在的镜像即可,必填
  2. environment: 定义环境变量,会在容器内转译成大写的环境变量。如: aaa 在容器内可通过 AAA 环境变量调用,非必填
  3. script: 定义Shell命令,非必填,可使用上面定义的环境变量

示例如下:

  1. shell-node:
  2. image: alpine:3.13.6
  3. script:
  4. - cd /home/
  5. - ls

其中:
shell-node:为节点的名称,可以自定义

5 网关节点

网关节点又分为并发网关节点和条件网关节点

  • 并发网关节点
    (1)如下图所示:start有两个下游节点,此两个节点即可以并发执行,end上游有两个节点,此两个节点也是可以并发执行的,以你次这里的start和end就被称为并发网关节点

    (2)通过sources定义多个上游节点

    1. end:
    2. sources:
    3. - feishu_notice_post1
    4. - feishu_notice_post2
    5. type: end

    (3)通过targets定义多个下游节点

    1. start:
    2. targets:
    3. - git_clone1
    4. - git_clone2
    5. type: start
  • 条件网关节点
    (1)如下,condition节点即如果condition为true,则执行上面的节点,如果为false则执行下面的节点,这种就是条件网关节点
    (2)定义语法如下:

    1. condition:
    2. sources:
    3. - start
    4. type: condition
    5. expression: ${event.number}>100
    6. cases:
    7. true: feishu_notice_post1
    8. false: feishu_notice_post2

    其中:${event.number}为事件参数,也可以为常量或其他参数

始终坚持开源开放共享精神,同时感谢您的充电鼓励和支持!
版权所有,转载本站文章请注明出处:redrose2100, http://blog.redrose2100.com/article/160
个人成就
  • 2022年 : 371 篇 
  • 2023年 : 211 篇 
  • 2024年 : 31 篇 
  • 2025年 : 0 篇 
  • 博客总数: 613 
  • 阅读总量: 714395 
测试开发技术全栈公众号
DevOps技术交流微信群