建木(Jianmu)----建木系统中的内置节点

简介: 建木(Jianmu)----建木系统中的内置节点

1 建木中节点的理解

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

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

2 开始节点的定义

start:
  targets:
    - test_step
  type: start

其中:

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

3 结束节点的定义

end:
  sources:
    - deploy
  type: end

其中:

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

4 shell-node节点定义

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

示例如下:

shell-node:
  image: alpine:3.13.6
  script:
    - cd /home/
    - ls

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

5 网关节点

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

  • 并发网关节点

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

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

end:
  sources:
    - feishu_notice_post1
    - feishu_notice_post2
  type: end

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

start:
  targets:
    - git_clone1
    - git_clone2
  type: start
  • 条件网关节点

(1)如下,condition节点即如果condition为true,则执行上面的节点,如果为false则执行下面的节点,这种就是条件网关节点
(2)定义语法如下:

condition:
  sources:
    - start
  type: condition
  expression: ${event.number}>100
  cases:
    true: feishu_notice_post1
    false: feishu_notice_post2

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

目录
相关文章
|
6月前
|
关系型数据库 数据库 PostgreSQL
《云杉树成长管理器》软件的安装部署
《云杉树成长管理器》软件的安装部署
《云杉树成长管理器》软件的安装部署
|
数据安全/隐私保护 Windows
OKCC系统搭建部署后如何使用?
【客户名称】:运营商登录的客户名称默认为dipcc 【用户名】:登录的用户名为admin 【密码】:初次登录系统
1146 0
OKCC系统搭建部署后如何使用?
|
3月前
|
Kubernetes jenkins 持续交付
微服务从代码到k8s部署应有尽有大结局(k8s部署)
微服务从代码到k8s部署应有尽有大结局(k8s部署)
|
3月前
|
Kubernetes 监控 数据安全/隐私保护
晓得用rancher怎么去管理K8S集群吗
晓得用rancher怎么去管理K8S集群吗
49 0
|
Kubernetes Devops Java
建木在 Rainbond 上使用实践
建木 是一个面向 DevOps 领域的极易扩展的开源无代码(图形化)/低代码(GitOps)工具,可以帮助用户轻松编排各种DevOps流程并分发到不同平台执行
|
资源调度 运维 Devops
建木(Jianmu)----迈出建木第一步创建项目分组
建木(Jianmu)----迈出建木第一步创建项目分组
436 0
建木(Jianmu)----迈出建木第一步创建项目分组
|
前端开发
建木(Jianmu)----建木系统中基于并发网关节点的流程Workflow
建木(Jianmu)----建木系统中基于并发网关节点的流程Workflow
184 0
建木(Jianmu)----建木系统中基于并发网关节点的流程Workflow
|
前端开发
建木(Jianmu)----建木系统中的管道Pipeline
建木(Jianmu)----建木系统中的管道Pipeline
227 0
建木(Jianmu)----建木系统中的管道Pipeline
|
Kubernetes 网络协议 API
纯手工搭建k8s集群-(二)核心模块部署
1. 部署ETCD(主节点) 1.1 简介 kubernetes需要存储很多东西,像它本身的节点信息,组件信息,还有通过kubernetes运行的pod,deployment,service等等。都需要持久化。
2507 0