前言

FluxCD 是 CNCF 的孵化项目,可以让我们以 GitOps 的方式轻松地交付应用。和另一个同类的 CNCF 孵化项目 ArgoCD 不同,FluxCD 是许多 toolkit 的集合,天然松耦合并且有良好的扩展性,用户可按需取用。我们希望通过集成 FluxCD 这样一个优秀的 GitOps 项目来为用户提供更多的选择。

我们综合考虑了以下三大要素:

  • 为还没有接触过 GitOps 的用户提供易上手的体验;
  • 为使用过 FluxCD 的用户提供无缝切换的体验;
  • 为已经使用过 KubeSphere GitOps 功能的用户提供熟悉感的同时突出 FluxCD 的优势和特性。

多次重新设计了前端界面和后端实现,最终完成了一个还算比较满意的版本。

ks-devops

设计

  • 模板复用:FluxCD 提供了 HelmChart 类型的 CRD,但是 HelmRelease 无法直接引用 HelmChart,我们希望添加模板的功能,这样许多配置就可以复用。
  • 多集群:我们希望 FluxApplication 是一个多集群应用,这样我们就可以用一套模板配置然后添加不同的配置去部署到多个集群中。

CRD

现有的 gitops.kubesphere.io/applications CRD 已经包含了 ArgoApplication。为了集成 FluxCD,我们将 FluxCD 中的 HelmReleaseKustomization 组合抽象成一个 FluxApplication 的概念放入 Application 里并且 kind 来标识用户启用了哪种 GitOps Engine。

一个完整的 GitOps 应用可以拆分成三大部分:

  1. :存放制品的仓库,制品包括是 Kubernetes Manifests、Kustomize 和 Helm,仓库的类型有 GitRepository、HelmRepository 以及 Bucket 等。
  2. 应用配置:对 Kustomize 可以是 pathpatches,对 Helm 可以是 valuesFromvalues
  3. 部署目标:制品的部署位置,是集群和相应名称空间的组合。

所以 FluxApplication 的具体实现如下,包含了 SourceConfig,由于 FluxCD 是一个多集群应用,一个部署目标对应一个应用配置,所以部署目标被包含在应用配置中。

type FluxApplicationSpec struct {
// Source represents the ground truth of the FluxCD Application
Source *FluxApplicationSource `json:"source,omitempty"`
// Config represents the Config of the FluxCD Application
Config *FluxApplicationConfig `json:"config"`
}

Controller

application-controllerstatus-controller 是管理 FluxCD 多集群应用的具体实现。以下是 FluxCD Helm 应用的示意图:

  • application-controller 负责 reconcile 自定义的多集群应用,解析自定义的 CR 然后转换成底层 FluxCD 的 CR 去驱动 FluxCD 的 kustomize-controllerhelm-controller 去应用的部署。
  • 可以为同一个 HelmTemplate 添加不同的应用配置和部署配置然后部署到多个集群中,还可以使用 FluxCD 的 pauseresume 功能,单独控制某个集群内应用的启停。
  • status-controller 使底层 FluxCD 应用状态透出到上层 gitops.kubesphere.io/application CR 中。

可视化界面

应用创建

为了使体验过 KubeSphere GitOps 功能的用户感到熟悉,我们在基础信息配置标签中选择和 ArgoCD 保持一致。虽然在应用配置和部署配置中 FluxCD 和 ArgoCD 存在相似之处,但是为了可维护性并且突出 FluxCD 的特点,我们重新设计了部署设置标签页,并且正在迭代之中。

  1. 在类型这一栏中,可以选择 HelmRelease 或者 Kustomization。在以后模板 API 全部开发完成之后,用户可以在此处选择模板类型,然后就可以选择保存的模板并将该模板部署到任意集群。

  1. 在配置这一栏里可以配置 Chart 和 ValuesFiles,现阶段如果需要配置 ValuesFiles 要使用分号将路径隔开,如:./helm-chart/values.yaml;./helm-chart/aliyun-values.yaml;并且可以选择是否将此配置保存为模板。
  2. 在部署这一栏中,用户可以为每一个部署位置配置不同的 Values、ValuesFrom 以及高级设置。Values 可以是任意 json 类型,是 helm install xxx --set 后面加的参数,例如:ports.traefik.expose=true;而 ValuesFrom 是 FluxCD 特有的内容,是一个类型为 ConfigMap 或 Secret 的数组,可以让用户更灵活的注入参数,用户可以单击标签选择类型:

  1. 为了满足高级用户的需求并且照顾到刚接触 GitOps 的用户,我们提供了高级设置。现阶段的高级设置包括:同步间隔、ReleaseName、StorageNamespace 以及原生的 Helm 操作参数。和 Helm 的原生操作类似,例如经常使用的安装命令 helm install xxx --create-namespace 中的--create-namespace 的 flag 就可以通过设置安装参数 createNamespace=True 来达到相同的效果,如果你熟悉 Helm,你一定能够在这里找到熟悉的感觉,因为 FluxCD 的 helm-controller 内部就是使用了原生的 helm 库来完成对应的操作。

应用管理

在创建好一个 FluxCD 应用之后,在持续部署的主页可以看到创建的应用的概要预览,其中包括应用的类型(HelmRelease|Kustomization)、源(GitRepository|HelmRepository|Bucket)、版本以及就绪个数,就绪个数的意思是,当选择将应用部署至多个位置时应用的就绪情况,例如将应用部署至三个集群内,其中两个集群中的应用已经处于 Ready 状态,另外一个集群内的应用还处于 Reconciling 的状态时,就绪个数为 2/3。用户还可以对该应用进行信息编辑,Yaml 编辑以及删除等操作。

点击应用名称可以进入应用详情页,在应用详情页可以看到应用的状态、部署位置、以及消息等内容,该部分会持续完善。

Demo

demo 视频的前端采用 kubesphere/console PR-3761;后端采用 kubesphere/ks-devops master branch

Demo Video

本文由博客一文多发平台 OpenWrite 发布!

FluxCD 多集群应用的设计与实现的更多相关文章

  1. dubbo源码解析五 --- 集群容错架构设计与原理分析

    欢迎来我的 Star Followers 后期后继续更新Dubbo别的文章 Dubbo 源码分析系列之一环境搭建 博客园 Dubbo 入门之二 --- 项目结构解析 博客园 Dubbo 源码分析系列之 ...

  2. 备战双 11!蚂蚁金服万级规模 K8s 集群管理系统如何设计?

    作者 | 蚂蚁金服技术专家 沧漠 关注『阿里巴巴云原生』公众号,回复关键词"1024",可获取本文 PPT. 前言 Kubernetes 以其超前的设计理念和优秀的技术架构,在容器 ...

  3. 新闻实时分析系统-HBase分布式集群部署与设计

    HBase是一个高可靠.高性能.面向列.可伸缩的分布式存储系统,利用Hbase技术可在廉价PC Server上搭建 大规模结构化存储集群. HBase 是Google Bigtable 的开源实现,与 ...

  4. 新闻网大数据实时分析可视化系统项目——6、HBase分布式集群部署与设计

    HBase是一个高可靠.高性能.面向列.可伸缩的分布式存储系统,利用Hbase技术可在廉价PC Server上搭建 大规模结构化存储集群. HBase 是Google Bigtable 的开源实现,与 ...

  5. HBase分布式集群部署与设计

    先是把cdh版本的hbase上传上来 把安装吧的权限设置一下 解压 把没用的东西干掉 hbase的官网 配置文件 到hbase-site.xml 下面我不基于HA配置了 把hbase分发到其他两个节点 ...

  6. RabbitMQ学习系列(六): RabbitMQ 高可用集群

    前面讲过一些RabbitMQ的安装和用法,也说了说RabbitMQ在一般的业务场景下如何使用.不知道的可以看我前面的博客,http://www.cnblogs.com/zhangweizhong/ca ...

  7. smartroute简单集成集群聊天通讯

    在制定一个规模比较多大的聊天应用时,往往需要制定部署多个应用服务,其一可以保障服务的可靠性,其二可以增加用户负载量.但制定这样一种应用体系是一件复杂的事情,毕竟同一群体的用户实际上会在不同的服务器接入 ...

  8. Rabbitmq集群高可用测试

    Rabbitmq集群高可用 RabbitMQ是用erlang开发的,集群非常方便,因为erlang天生就是一门分布式语言,但其本身并不支持负载均衡. Rabbit模式大概分为以下三种:单一模式.普通模 ...

  9. Mongodb集群【三】

    Mongodb常用三种集群 1 主从(Master/Slave) 不推荐,但是mongodb依然保留有.一主多从,不支持链式结构.简单主从,没有裁仲者不能自动恢复. 2 副本集(Relica Set) ...

  10. Rabbitmq集群

    分享到 一键分享 QQ空间 新浪微博 百度云收藏 人人网 腾讯微博 百度相册 开心网 腾讯朋友 百度贴吧 豆瓣网 搜狐微博 百度新首页 QQ好友 和讯微博 更多... 百度分享 Rabbitmq集群高 ...

随机推荐

  1. 搞笑视频 —— 每天一乐 —— "齐老师妙~啊!"

    视频地址: https://quanmin.baidu.com/v/7250265959743227122

  2. baselines算法库common/vec_env/dummy_vec_env.py模块分析

    baselines算法库设计可以和多个并行环境进行交互,也就是并行采样,实现多进程并行采样的模块为subproc_vec_env.py,与此相对的只实现单个进程下多环境交互的模块即为本文所要讲的dum ...

  3. JVM指令大全之不太全系列

    一.未归类系列A 此系列暂未归类. 指令码    助记符                            说明0x00         nop                           ...

  4. C# 导出Excel NPOI 修改指定单元格的样式 或者行样式

    参考文章:原文链接:https://blog.csdn.net/chensirbbk/article/details/52189985 #region 2.NPOI读取Excel 验证Excel数据的 ...

  5. NeoVim 安装

    NeoVim 官网 安装 macOS brew install neovim Windows 使用 winget: winget install Neovim.Neovim 也可以使用 scoop: ...

  6. NET Core 多身份校验与策略模式

    背景需求:   系统需要对接到XXX官方的API,但因此官方对接以及管理都十分严格.而本人部门的系统中包含诸多子系统,系统间为了稳定,程序间多数固定Token+特殊验证进行调用,且后期还要提供给其他兄 ...

  7. release版本 APP 出现waiting for debugger

    前提:同一包代码,打包两个版本,修改包名,在同一设备上存在两个版本 状态:运行时,发现 一版本是正常 另一版本打开会提示 Waiting for debugger弹窗,(此时由于是开发状态,设备一直开 ...

  8. node: /lib64/libm.so.6: version `GLIBC_2.27‘ not found问题解决方案

    场景 centos7服务器使用nvm安装的node之后,只要使用npm或者node,均会出现以下问题. npm -v node: /lib64/libm.so.6: version `GLIBC_2. ...

  9. OpenAI注册-临时手机号/邮箱

    OpenAI 在注册ChatGPT时,发生了一个错误,使用邮箱进行注册后,在注册界面会提示"Not available OpenAI's services are not available ...

  10. ubuntu 20.04安装GCC G++ 6.2,支持c++ 14

    1. 下载源码包 wget http://ftp.gnu.org/gnu/gcc/gcc-6.2.0/gcc-6.2.0.tar.bz2 2. 解压 tar jxf gcc-6.2.0.tar.bz2 ...