25.云原生之ArgoCD-app of apps模式

文章目录

app of apps 模式介绍

通过一个app来管理其他app,当有多个项目要发布创建多个app比较麻烦,此时可以创建一个管理app,管理app创建后会创建其他app。比较适合项目环境迁移的场景。

App of Apps模式优点:

  1. 统一管理:通过一个主要的应用程序,你可以统一管理多个应用程序的生命周期。这样可以简化管理和操作,减少重复劳动。
  2. 集中控制:"App of Apps"应用程序充当了一个控制中心,你可以通过它来管理整个应用程序集群的状态和配置。这样可以提高集中控制的能力,并确保所有应用程序的一致性。
  3. 版本控制:通过将应用程序定义文件存储在Git仓库中,你可以轻松地跟踪和管理应用程序的版本。这样可以实现版本控制和回滚,确保应用程序的可追溯性和可控性。
  4. 多环境支持:"App of Apps"模式可以支持多个环境(如开发、测试和生产环境)的部署。通过在主要应用程序中定义不同环境的应用程序配置,可以轻松地在不同环境中部署和管理应用程序。

app如何管理app

  1. 查看配置app对应的k8s资源内容

    java 复制代码
    kubectl get applications --all-namespaces
  2. 查看应用程序资源的内容:

    复制代码
    kubectl get application <application-name> -n <namespace> -o yaml

核心配置如下,下述配置其实就是在ArgoCD创建应用对应的配置

java 复制代码
apiVersion: argoproj.io/v1alpha1
kind: Application
metadata:
  name: app1
  namespace: argocd
spec:
  destination:
    namespace: directory-guestbook-1
    server: https://kubernetes.default.svc
  project: default
  source:
    path: guestbook
    repoURL: https://gitee.com/gmkk/argocd-example-apps.git
    targetRevision: main
    directory:
      recurse: true
  syncPolicy:
    syncOptions:
      - CreateNamespace=true

管理app通过配置文件描述,有helm和kustomize方式,如下:

helm方式管理

官网案例参考:https://github.com/argoproj/argocd-example-apps

注意:在Argocd中创建应用需要选择Helm

kustomize方式管理

案例参考:https://gitee.com/gmkk/argocd-example-apps

rootapp:

yaml 复制代码
apiVersion: argoproj.io/v1alpha1
kind: Application
metadata:
  name: root-application
  namespace: argocd
spec:
  project: default
  source:
    repoURL: https://gitee.com/gmkk/argocd-example-apps.git
    targetRevision: HEAD
    # 其他Application路径
    path: ./app-of-apps/apps
    # directory
    directory:
      recurse: false
  destination:
    server: https://kubernetes.default.svc
    namespace: default
相关推荐
掘金-我是哪吒2 小时前
分布式微服务系统架构第145集:Jeskson文档-微服务分布式系统架构
分布式·微服务·云原生·架构·系统架构
国际云,接待10 小时前
微软云注册被阻止怎么解决?
服务器·网络·microsoft·云原生·微软·云计算
老实巴交的麻匪12 小时前
可观测性 | Grafana Loki 日志聚合方案快速体验
运维·云原生·容器
炎码工坊16 小时前
DevSecOps实践:CI/CD流水线集成动态安全测试(DAST)工具
安全·网络安全·微服务·云原生·安全架构
Akamai中国17 小时前
为何AI推理正推动云计算从集中式向分布式转型
人工智能·云原生·云计算·边缘计算
程序员阿超的博客19 小时前
云原生核心技术 (9/12): K8s 实战:如何管理应用的配置 (ConfigMap/Secret) 与数据 (Volume)?
云原生·容器·kubernetes
hackchen1 天前
NexusTerminal一款视频移动端的webSSH
docker·云原生·eureka·web-ssh
ahhhhaaaa-1 天前
【k8s】阿里云ACK服务中GPU实例部署问题
阿里云·云原生·容器·kubernetes·云计算
熊出没1 天前
阿里云云原生数据库PolarDB和普通云数据库的区别?
数据库·阿里云·云原生
上海运维Q先生2 天前
Cilium动手实验室: 精通之旅---20.Isovalent Enterprise for Cilium: Zero Trust Visibility
云原生·k8s·cilium