首页
学习
活动
专区
圈层
工具
发布
社区首页 >专栏 >天呐!我用 go 从零开始写了一个 k8s 应用管理工具(附完整代码和开发过程)

天呐!我用 go 从零开始写了一个 k8s 应用管理工具(附完整代码和开发过程)

作者头像
老麦
发布2023-02-25 19:47:34
发布2023-02-25 19:47:34
6530
举报
文章被收录于专栏:Go与云原生Go与云原生

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

kustz 的设计思想和定义

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

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

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

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

  1. Deployment API 定义
代码语言:javascript
复制
## 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 定义
代码语言:javascript
复制
## 2. k8s Service API 定义
  ports:
    - "80:8080" # cluster ip
    - "udp://!9998:8889" # 随机 nodeport
    # - "!20080:80:8080" # 指定 nodeport
  1. k8s Ingress API 定义
代码语言:javascript
复制
## 3. k8s Ingress API 定义
ingress:
  rules:
    - http://api.example.com/ping?tls=star-example-com&svc=srv-webapp-demo:8080

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

使用方式

kustz 使用 cobra 实现命令功能。

代码语言:javascript
复制
$ 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

代码语言:javascript
复制
# 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

代码语言:javascript
复制
# 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 查看变更。

楔子

第一章 完成基本框架

第二章 服务高级抽象

第三章 工程化

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2022-12-30,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 熊猫云原生Go 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • Kustz 让应用在 Kubernetes 中管理更简单
    • kustz 的设计思想和定义
    • 使用方式
    • 为什么会有 kustz
      • Kustomize
    • 开源仓库
    • 楔子
    • 第一章 完成基本框架
    • 第二章 服务高级抽象
    • 第三章 工程化
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档