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

简介: Kustz 让应用在 Kubernetes 中管理更简单

Kustz 让应用在 Kubernetes 中管理更简单

image.png

kustz 的设计思想和定义

kustz 的一个核心理念就是 语义话, 换句话说就是具有 可读性 高, 见名知义

力求 kustz.yml 之于 应用, 就像 域名 至于 IP

对于一个服务应用来说, 所有的定义都在同一个配置文件里面, 不再割裂。

kustz 的完整配置 中可以看到, 主要的参数都进行了 语义化 的处理和简化, 更贴近生活语言。

  1. Deployment API 定义
## 1. k8s Deployment API 定义
  name: nginx
  image: docker.io/library/nginx:alpine
  replicas: 2
  envs:
    pairs:
      key1: value1
    configmaps:
      - srv-webapp-demo-envs:true
  resources:
    cpu: 10m/20m
    memory: 10Mi/20Mi
    nvidia.com/gpu: 1/1
  probes:
    liveness:
      action: http://:8080/healthy
  1. Service API 定义
## 2. k8s Service API 定义
  ports:
    - "80:8080" # cluster ip
    - "udp://!9998:8889" # 随机 nodeport
    # - "!20080:80:8080" # 指定 nodeport
  1. k8s Ingress API 定义
## 3. k8s Ingress API 定义
ingress:
  rules:
    - http://api.example.com/ping?tls=star-example-com&svc=srv-webapp-demo:8080

既然现在的工具满足不了我们, 我们就自己抽象一层, 自己实现一个工具。

使用方式

kustz 使用 cobra 实现命令功能。

$ kustz -h
快速定义 k8s 应用配置

Usage:
  kustz [flags]
  kustz [command]

Available Commands:
  completion  Generate the autocompletion script for the specified shell
  default     在屏幕上打印 kustz 默认配置
  help        Help about any command
  render      读取 kustz 配置, 生成 kustomize 所需文件

Flags:
  -h, --help   help for kustz

Use "kustz [command] --help" for more information about a command.

目前实现了两个子命令

  1. default: 在屏幕上打印 kustz 默认配置, 可以通过重定向符号保存到文件中。
  2. render: 读取 kustz.yml 配置文件, 并渲染成对应的 Config API

使用 demo

# 1. 生成配置文件
$ kustz default > myapp.kustz.yml
# 2. 修改配置文件
$ vi myapp.kustz.yml
# 3. 渲染配置文件
$ kustz render -c myapp.kustz.yml
# 4. 使用 kustomize 发布。
$ kubectl apply -k .

为什么会有 kustz

你有没有想过, 如果要在 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)

Kustomize

下面是 kustomize 最基本的配置文件 kustomization.yaml

# kustomization.yaml
apiVersion: kustomize.config.k8s.io/v1beta1
kind: Kustomization
namespace: demo-demo
resources:
  - deployment.yml
  - service.yml
  - ingress.yml
configMapGenerator:
- name: my-application-properties
  files:
  - application.properties

更多参数, 可以到 kustomize 官网 查看。

可以看到 kustomize 也只是帮我们完成了文件的组合, 并没有解决 Config API 复杂结构的问题。

开源仓库

所有代码都已经过开源在 Github: https://github.com/tangx/kustz
阅读过程中, 可以直接可以参考代码。

每一章节都都对应一个 TAG , 如果需要跟着练习实现, 可以按照每个 TAG 查看变更。

引用

相关实践学习
深入解析Docker容器化技术
Docker是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的Linux机器上,也可以实现虚拟化,容器是完全使用沙箱机制,相互之间不会有任何接口。Docker是世界领先的软件容器平台。开发人员利用Docker可以消除协作编码时“在我的机器上可正常工作”的问题。运维人员利用Docker可以在隔离容器中并行运行和管理应用,获得更好的计算密度。企业利用Docker可以构建敏捷的软件交付管道,以更快的速度、更高的安全性和可靠的信誉为Linux和Windows Server应用发布新功能。 在本套课程中,我们将全面的讲解Docker技术栈,从环境安装到容器、镜像操作以及生产环境如何部署开发的微服务应用。本课程由黑马程序员提供。     相关的阿里云产品:容器服务 ACK 容器服务 Kubernetes 版(简称 ACK)提供高性能可伸缩的容器应用管理能力,支持企业级容器化应用的全生命周期管理。整合阿里云虚拟化、存储、网络和安全能力,打造云端最佳容器化应用运行环境。 了解产品详情: https://www.aliyun.com/product/kubernetes
相关文章
|
9月前
|
缓存 Kubernetes Docker
GitLab Runner 全面解析:Kubernetes 环境下的应用
GitLab Runner 是 GitLab CI/CD 的核心组件,负责执行由 `.gitlab-ci.yml` 定义的任务。它支持多种执行方式(如 Shell、Docker、Kubernetes),可在不同环境中运行作业。本文详细介绍了 GitLab Runner 的基本概念、功能特点及使用方法,重点探讨了流水线缓存(以 Python 项目为例)和构建镜像的应用,特别是在 Kubernetes 环境中的配置与优化。通过合理配置缓存和镜像构建,能够显著提升 CI/CD 流水线的效率和可靠性,助力开发团队实现持续集成与交付的目标。
|
9月前
|
存储 监控 对象存储
ACK 容器监控存储全面更新:让您的应用运行更稳定、更透明
针对本地存储和 PVC 这两种容器存储使用方式,我们对 ACK 的容器存储监控功能进行了全新升级。此次更新完善了对集群中不同存储类型的监控能力,不仅对之前已有的监控大盘进行了优化,还针对不同的云存储类型,上线了全新的监控大盘,确保用户能够更好地理解和管理容器业务应用的存储资源。
578 276
|
8月前
|
Kubernetes 持续交付 开发工具
阿里云协同万兴科技落地ACK One GitOps方案,全球多机房应用自动化发布,效率提升50%
阿里云协同万兴科技落地ACK One GitOps方案,全球多机房应用自动化发布,效率提升50%
233 2
|
7月前
|
存储 监控 对象存储
ACK 容器监控存储全面更新:让您的应用运行更稳定、更透明
ACK 容器监控存储全面更新:让您的应用运行更稳定、更透明
163 0
ACK 容器监控存储全面更新:让您的应用运行更稳定、更透明
|
8月前
|
存储 监控 对象存储
ACK 容器监控存储全面更新:让您的应用运行更稳定、更透明
ACK 容器监控存储全面更新:让您的应用运行更稳定、更透明
121 1
|
8月前
|
Kubernetes 持续交付 开发工具
阿里云协同万兴科技落地ACK One GitOps方案,全球多机房应用自动化发布,效率提升50%
阿里云协同万兴科技落地ACK One GitOps方案,全球多机房应用自动化发布,效率提升50%
|
9月前
|
存储 监控 对象存储
ACK容器监控存储全面更新:让您的应用运行更稳定、更透明
介绍升级之后的ACK容器监控体系,包括各大盘界面展示和概要介绍。
|
8月前
|
运维 分布式计算 Kubernetes
ACK One多集群Service帮助大批量应用跨集群无缝迁移
ACK One多集群Service可以帮助您,在无需关注服务间的依赖,和最小化迁移风险的前提下,完成跨集群无缝迁移大批量应用。
|
10月前
|
人工智能 Kubernetes 安全
赋能加速AI应用交付,F5 BIG-IP Next for Kubernetes方案解读
赋能加速AI应用交付,F5 BIG-IP Next for Kubernetes方案解读
189 13
|
10月前
|
存储 Kubernetes 关系型数据库
阿里云ACK备份中心,K8s集群业务应用数据的一站式灾备方案
本文源自2024云栖大会苏雅诗的演讲,探讨了K8s集群业务为何需要灾备及其重要性。文中强调了集群与业务高可用配置对稳定性的重要性,并指出人为误操作等风险,建议实施周期性和特定情况下的灾备措施。针对容器化业务,提出了灾备的新特性与需求,包括工作负载为核心、云资源信息的备份,以及有状态应用的数据保护。介绍了ACK推出的备份中心解决方案,支持命名空间、标签、资源类型等维度的备份,并具备存储卷数据保护功能,能够满足GitOps流程企业的特定需求。此外,还详细描述了备份中心的使用流程、控制台展示、灾备难点及解决方案等内容,展示了备份中心如何有效应对K8s集群资源和存储卷数据的灾备挑战。

热门文章

最新文章

推荐镜像

更多