k8s argo工作流

argo简介

argo 是一个基于 kubernetes CRD 实现的一个 Workflow(工作流) 工具,基于 kubernetes 的调度能力实现了工作流的控制和任务的运行,同时提供了一个 Dashboard来方便我们查看任务的进程和详情。

ArgoCD功能有哪些?

  • 将应用程序自动部署到指定环境中
  • 可通过CRD方式定义执行对象
  • 多租户管理和RBAC权限集成管控
  • 多集应用管理和部署
  • 可视化UI
  • 支持多种Kubernetes配置对象(Kustomize,Helm,Ksonnet,Jsonnet,plain-YAML)
  • 支持SSO集成(OIDC,OAuth2,LDAP,SAML 2.0,GitHub,GitLab,Microsoft,LinkedIn)
  • Webhook集成可实现通知
  • 自带metric指标暴露

argo根据前置任务执行状态判断是否继续执行后续任务

apiVersion: argoproj.io/v1alpha1
kind: CronWorkflow
metadata:
  name: coinflip-cron
spec:
  schedule: "* * * * *"
  concurrencyPolicy: Forbid
  successfulJobsHistoryLimit: 1
  failedJobsHistoryLimit: 1
  startingDeadlineSeconds: 0
  workflowSpec:
    entrypoint: coinflip
    templates:
      - name: coinflip
        steps:
          - - name: flip-coin
              template: flip-coin
          - - name: heads
              template: heads
              when: "{{steps.flip-coin.exitCode}} == 0"

      - name: flip-coin
        script:
          image: python:alpine3.6
          command: [python]
          source: |
            import random
            result = 0 if random.randint(0,1) == 0 else 1
            print("heads")
            sys.exit(result)

      - name: heads
        container:
          image: alpine:3.6
          command: [sh, -c]
          args: ["echo \"it was heads\""]
          ```
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值