在 KubeSphere 上快速安装和使用 KDP 云原生数据平台
![在 KubeSphere 上快速安装和使用 KDP 云原生数据平台](https://static001.geekbang.org/infoq/c3/c316eb266d5cd6150c166d72a47b671a.png)
金津,智领云高级研发经理。
华中科技大学计算机系硕士。加入智领云 7 余年,长期从事云原生、容器化编排领域研发工作,主导了智领云自研的 BDOS 应用云平台、云原生大数据平台 KDP 等产品的开发,并在多个大规模项目中成功实施落地,在大规模容器化编排系统方向有丰富的实践经验。
在 KubeSphere 上部署 KDP
技术简介
KubeKey[1]
KubeKey 是一个开源的 Kubernetes 安装程序和生命周期管理工具。它支持安装 Kubernetes 集群、KubeSphere 以及其他相关组件。
KubeSphere[2]
KubeSphere 是一个用于云原生应用程序管理的分布式操作系统,使用 Kubernetes 作为其内核。它提供了即插即用架构,允许第三方应用程序无缝集成到其生态系统中。
Kubernetes Data Platform[3]
KDP(Kubernetes Data Platform)提供了一个基于 Kubernetes 的现代化混合云原生数据平台,能够利用 Kubernetes 的云原生能力来有效地管理数据平台。KDP 是构建在 Kubernetes 之上的,因此可以与任意的 Kubernetes 管理平台快速集成。
总的来说,KubeSphere 和 KDP 组合在一起,能够为用户提供一套完善的、强大的、基于 Kubernetes 的现代化云原生应用数据平台。未来,通过 KubeSphere 的 LuBan 集成框架,可以将 KDP 开发成为 KubeSphere 的扩展组件,从而进一步深度融合进 KubeSphere。
先决条件
在 Kubernetes 上已安装 KubeSphere(快速开始可参考在 Kubernetes 上最小化安装 KubeSphere[4]):
![](https://static001.geekbang.org/infoq/15/15e4fb3611ec8ace273e7ba5a5312d13.png)
KubeSphere 安装完成后,登录 KubeSphere Web 控制台并确保监控组件已启用:
![](https://static001.geekbang.org/infoq/03/031dd8a8af952f5b0ab06cac25a6745a.png)
安装 KDP
假设您已经在一个 v1.26.x Kubernetes 集群上安装了 KubeSphere ,并开启了监控套件。
安装 KDP 命令行工具
可选使用本地终端工具或 KubeSphere 网页终端进行操作:
通过本地 Shell:打开您计算机上的 Bash 或 Zsh 终端。
通过 Web Kubectl[5]:
![](https://static001.geekbang.org/infoq/7c/7c0949ca953f19e4c6394f111d653732.png)
在网页或本地终端中,请执行以下命令以安装 KDP 命令行工具(注:若使用网页终端,因其无状态特性,每次新建立会话都需要重新安装 KDP 命令行工具):
安装 KDP 基础平台
执行以下命令以安装 KDP 基础平台:
访问 KDP UX
等待安装完成:
![](https://static001.geekbang.org/infoq/62/627f7aff3a2e3a8eacd037c7b309fb78.png)
转到 KubeSphere Web 控制台,并在菜单 “应用负载” -> “应用路由” 中找到名为 'kdp-ux' 的应用路由对象:
![](https://static001.geekbang.org/infoq/a2/a239229a1fe747f679aed6248a952410.png)
点击并进入'kdp-ux'应用路由的详细页面,然后点击路径'/'的'访问服务'按钮,KDP UX 将在新标签页中打开:
![](https://static001.geekbang.org/infoq/32/3290da9a3a183ffb1a48e8a587e8fa74.png)
您现在可以使用 KDP Web 控制台来建设自己的数据平台。有关使用数据组件的更多教程,请参考教程目录[6]:
![](https://static001.geekbang.org/infoq/0e/0edc3e6daab74a90b8965b804c3351df.png)
在 KDP 上快速交付 Kafka
KDP 提供开箱即用的开源 Kafka K8s 运行时,主要包括:Strimzi Kafka Operator、Kafka Cluster、Kafka Manager 等。用户通过 KDP 可以高效便捷地交付和运维 Kafka 套件,KDP 为数据组件运行时提供完善的生命周期管理以及监控、告警、日志的自动化集成。
Kafka 简介
Kafka[7],Apache Kafka 是一个分布式事件流平台。基于 Kafka,可以构建高吞吐量、高扩展性的消息中间件服务。适用于日志采集、流式数据处理、流量削峰填谷等场景。Kafka 具备高可靠、高并发访问、可扩展的特性是大数据生态系统中不可或缺的组成部分。
在 KDP 上部署 Kafka 套件
以下展示的是如何在 KDP 上快速交付 Kafka 套件:
通过 KDP 应用目录安装 Kafka Operator 及 Kafka Cluster
![](https://static001.geekbang.org/infoq/68/68a50c33be406fb954b85230d655cc75.jpeg?x-oss-process=image%2Fresize%2Cp_80%2Fauto-orient%2C1)
部署过程中可以实时查看 Pod 日志
![](https://static001.geekbang.org/infoq/6e/6e1977e16c2d1ee74718bbedb30f089b.jpeg?x-oss-process=image%2Fresize%2Cp_80%2Fauto-orient%2C1)
待 ZK 集群与 Kakfa 集群所有 Pod 运行就绪
![](https://static001.geekbang.org/infoq/95/957a9d583a4acc8cc4fd4fc545e3ea8a.jpeg?x-oss-process=image%2Fresize%2Cp_80%2Fauto-orient%2C1)
KDP 提供应用实例下所有底层 K8s 资源拓扑展示
![](https://static001.geekbang.org/infoq/da/da6f0153c18e29ff37ae0ea350d8224b.jpeg?x-oss-process=image%2Fresize%2Cp_80%2Fauto-orient%2C1)
待 Kafka Cluster 运行正常后,继续安装好 Kafka Manager;完成后,应用实例界面右上角可快速打开 Kafka Manager 的页面
![](https://static001.geekbang.org/infoq/00/00e4361fc291c421032f157ec5e42ce3.jpeg?x-oss-process=image%2Fresize%2Cp_80%2Fauto-orient%2C1)
创建一个 Topic
以上我们已经在 KDP 上快速交付了一套 Kafka Cluster 以及 Kafka Manager(开源的 Kafka 界面管理工具),接下来我们基于 Kafka 界面管理工具来创建一个 Topic:
进入 Kafka Manager 界面,可以看到已自动导入我们安装好的 Kafka Cluster
![](https://static001.geekbang.org/infoq/5f/5fb81889ad54fbd0327c5f5174cd78f8.jpeg?x-oss-process=image%2Fresize%2Cp_80%2Fauto-orient%2C1)
在 Kafka Manager 界面上创建一个 topic "my-2nd-topic"
![](https://static001.geekbang.org/infoq/e6/e6ff6d95fc964488fa816d59ae5c9085.jpeg?x-oss-process=image%2Fresize%2Cp_80%2Fauto-orient%2C1)
完成后,在 Topic 列表中可以看到我们新建的 topic
![](https://static001.geekbang.org/infoq/39/397b8eb8b27d1b499f1fbf06c3c0140b.jpeg?x-oss-process=image%2Fresize%2Cp_80%2Fauto-orient%2C1)
从 KDP 内置的监控面板上 topic 的指标数据中,我们也可以观测到 topic 数量从 1 变为了 2
![](https://static001.geekbang.org/infoq/5f/5ff18b361c4fb86cd6a73cc134e0d1c1.jpeg?x-oss-process=image%2Fresize%2Cp_80%2Fauto-orient%2C1)
相关链接
【教程文档】在 KubeSphere 上安装 KDP 101:https://linktimecloud.github.io/kubernetes-data-platform/docs/zh/user-tutorials/install-kdp-on-kubesphere-101.html
【教程文档】如何与 KDP 上的 Kafka 快速集成:https://linktimecloud.github.io/kubernetes-data-platform/docs/zh/user-tutorials/integration-kafka-with-int-ext-comps.html
【演示视频】如何在 KubeSphere 容器平台上快速部署和使用 KDP :
引用链接
[1]KubeKey: https://github.com/kubesphere/kubekey
[2]KubeSphere: https://github.com/kubesphere/kubesphere
[3]Kubernetes Data Platform: https://www.linktimecloud.com/kubernetes-data-platform
[4]快速开始可参考在 Kubernetes 上最小化安装 KubeSphere: https://kubesphere.io/zh/docs/v3.4/quick-start/minimal-kubesphere-on-k8s/
[5]Web Kubectl: https://kubesphere.io/zh/docs/v3.4/toolbox/web-kubectl/
[7]Kafka: https://linktimecloud.github.io/kubernetes-data-platform/docs/zh/catalog-overview/Kafka/overview.htm
版权声明: 本文为 InfoQ 作者【智领云科技】的原创文章。
原文链接:【http://xie.infoq.cn/article/666204000a16f588ef607c946】。文章转载请联系作者。
评论