[kustz] 从零开始写一个 k8s 应用发布工具(含源码和过程)

简介: 你有没有想过, 如果要在 kubernetes 集群中 **发布** 一个最基本的 **无状态服务**, 并 **提供** 给用户访问, 最少需要配置几个 `K8S Config API` ?自己写一个, 提升自己。

[kustz] 从零开始写一个 k8s 应用发布工具(含源码和过程)

你有没有想过, 如果要在 kubernetes 集群中 发布 一个最基本的 无状态服务, 并 提供 给用户访问, 最少需要配置几个 K8S Config API ?

  1. Deployment: 管理应用本身。
  2. Service: 管理应用在集群内的访问地址, 也是应用在在集群累的负载均衡器。
  3. Ingress: 管理应用对外暴露的入口, 通俗点说, 就是 URL。

前三个是最基本的的 API。

如果还有配置文件或或者其他密钥管理, 可能你还需要。

  1. Secret / ConfigMap: 管理应用配置。

这些配置文件的存在, 本身都独立存在, 并没什么关系。

为了让他们在一起, 你还需要定义 Label 信息, 并且通过 LabelSelector 将他们组合起来。

只是将这些 Config API 文件组合在一起, 都是一件麻烦事情了。 这还不包括各个 Config API 本身的复杂结构, 以及不同版本之间的差别。

社区也注意到这件事情了, 有很多工具帮我们组合管理, 例如我们今天要说的 Kustomize

除此之外, 还有微软和阿里云一起搞的 Open Application Model(简称 OAM)。

image.png

简介

【开个坑】 kustz 快速发布应用到 Kubernetes

1.2 [kustz] 简介和设计思路

基本框架

2.1 [kustz] 先从模仿创建 Deployment 开始

2.2. [kustz] 定义字符串创建 Service

2.3. [kustz] 解析 URL 为 Ingress

2.4. [kustz] kustomize 流水线

2.5. [kustz] 使用 cobra 实现 kustz 命令

功能扩展

3.1. [kustz] 为 Container 添加环境变量

3.2. [kustz] ConfigMap 和 Secret 的生成器

3.3. [kustz] 注入 ConfigMap 和 Secrets 到容器环境变量

3.4 [kustz] 用字符串定义容器申请资源上下限

3.5 [kustz] 为 Container 添加健康检查方法

3.6. [kustz] 镜像拉取鉴权和策略

投入生产

4.1. [kustz] 使用 cobrautils 为命令添加更实用的命令参数

总结

自己从零开发一个 Kustz, 让应用在 Kubernetes 中管理更简单

相关实践学习
通过Ingress进行灰度发布
本场景您将运行一个简单的应用,部署一个新的应用用于新的发布,并通过Ingress能力实现灰度发布。
容器应用与集群管理
欢迎来到《容器应用与集群管理》课程,本课程是“云原生容器Clouder认证“系列中的第二阶段。课程将向您介绍与容器集群相关的概念和技术,这些概念和技术可以帮助您了解阿里云容器服务ACK/ACK Serverless的使用。同时,本课程也会向您介绍可以采取的工具、方法和可操作步骤,以帮助您了解如何基于容器服务ACK Serverless构建和管理企业级应用。 学习完本课程后,您将能够: 掌握容器集群、容器编排的基本概念 掌握Kubernetes的基础概念及核心思想 掌握阿里云容器服务ACK/ACK Serverless概念及使用方法 基于容器服务ACK Serverless搭建和管理企业级网站应用
相关文章
|
16天前
|
人工智能 Kubernetes 安全
赋能加速AI应用交付,F5 BIG-IP Next for Kubernetes方案解读
赋能加速AI应用交付,F5 BIG-IP Next for Kubernetes方案解读
56 13
|
16天前
|
存储 Kubernetes 关系型数据库
阿里云ACK备份中心,K8s集群业务应用数据的一站式灾备方案
本文源自2024云栖大会苏雅诗的演讲,探讨了K8s集群业务为何需要灾备及其重要性。文中强调了集群与业务高可用配置对稳定性的重要性,并指出人为误操作等风险,建议实施周期性和特定情况下的灾备措施。针对容器化业务,提出了灾备的新特性与需求,包括工作负载为核心、云资源信息的备份,以及有状态应用的数据保护。介绍了ACK推出的备份中心解决方案,支持命名空间、标签、资源类型等维度的备份,并具备存储卷数据保护功能,能够满足GitOps流程企业的特定需求。此外,还详细描述了备份中心的使用流程、控制台展示、灾备难点及解决方案等内容,展示了备份中心如何有效应对K8s集群资源和存储卷数据的灾备挑战。
|
1月前
|
存储 运维 Kubernetes
K8s业务迁移最佳实践: 灵活管理资源备份与调整策略,实现高效简便的应用恢复
在当今快速变化的云原生领域,Kubernetes(K8s)集群的运维面临着诸多挑战,其中灾备与业务迁移尤为关键。ACK备份中心支持丰富的资源调整策略,在数据恢复阶段即可自动适配目标集群环境,确保业务无缝重启。
|
1月前
|
监控 持续交付 Docker
Docker 容器化部署在微服务架构中的应用有哪些?
Docker 容器化部署在微服务架构中的应用有哪些?
|
1月前
|
监控 持续交付 Docker
Docker容器化部署在微服务架构中的应用
Docker容器化部署在微服务架构中的应用
|
1月前
|
JavaScript 持续交付 Docker
解锁新技能:Docker容器化部署在微服务架构中的应用
【10月更文挑战第29天】在数字化转型中,微服务架构因灵活性和可扩展性成为企业首选。Docker容器化技术为微服务的部署和管理带来革命性变化。本文探讨Docker在微服务架构中的应用,包括隔离性、可移植性、扩展性、版本控制等方面,并提供代码示例。
62 1
|
1月前
|
Kubernetes 安全 容器
关于K8s,不错的开源工具
【10月更文挑战第12天】
|
2月前
|
JSON Kubernetes 容灾
ACK One应用分发上线:高效管理多集群应用
ACK One应用分发上线,主要介绍了新能力的使用场景
|
1月前
|
Kubernetes 监控 安全
容器化技术:Docker与Kubernetes的实战应用
容器化技术:Docker与Kubernetes的实战应用
|
1月前
|
Java Docker 微服务
利用Docker容器化部署Spring Boot应用
利用Docker容器化部署Spring Boot应用
51 0

热门文章

最新文章

推荐镜像

更多