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
相关推荐
云上艺旅3 小时前
K8S学习之基础六十八:Rancher创建deployments资源
学习·云原生·容器·kubernetes·rancher
rider1893 小时前
【4】搭建k8s集群系列(二进制部署)之安装master节点服务(kube-apiserver)
云原生·容器·kubernetes
GreenMountainEcho11 小时前
Kubernetes 入门篇之 Node 安装与部署
云原生·容器·kubernetes
alden_ygq14 小时前
k8s statefulset pod重启顺序
云原生·容器·kubernetes
云上艺旅17 小时前
K8S学习之基础七十二:Ingress基于Https代理pod
学习·云原生·容器·https·kubernetes
liux352817 小时前
k8s之Ingress讲解
云原生·容器·kubernetes
阿里云云原生17 小时前
函数计算支持热门 MCP Server 一键部署
云原生
阿里云云原生18 小时前
AI 网关代理 LLMs 最佳实践
云原生
小刘爱喇石( ˝ᗢ̈˝ )21 小时前
玛卡巴卡的k8s知识点问答题(六)
云原生·容器·kubernetes
rider18921 小时前
【1】搭建k8s集群系列(二进制部署)之系统初始化
云原生·容器·kubernetes