https://github.com/cubxxw/client-go

想要介绍 Kubernetes Client-Go, 那必须提前介绍 Kubernetes API

Kubernetes API

Kubernetes API是一组REST API,用于与Kubernetes集群交互。这些API允许开发人员执行各种操作,包括管理Pod、Deployment、Service、Namespace等。Kubernetes API由一组资源对象表示,例如Pod、Service、ReplicaSet等。这些资源对象由Kubernetes API Server管理,并可以通过kubectl等工具进行查询和修改。

Kubernetes API Server 提供的是默认的 HTTPS 服务,而且是双向的 TLS 认证,而我们目前的关注点是 API 本身,因此先通过 Kubectl 来代理 API Server 服务。

kubectl proxy --port=8080

接下来就可以通过简单的 HTTP 请求来和 API Server 交互了:

curl localhost:8080/version

我们可能还需要一个配置文件来描述 Deployment 资源,在本地创建一个 nginx-deploy.yaml 文件:

apiVersion: apps/v1
kind: Deployment
metadata:
  name: nginx-deployment
spec:
  replicas: 3
  selector:
    matchLabels:
      app: nginx
  template:
    metadata:
      labels:
        app: nginx
    spec:
      containers:
      - name: nginx
        image: nginx:1.14.2
        ports:
        - containerPort: 80

要在 Kubernetes 集群中创建这个 Deployment 资源,可以使用 kubectl create 命令:

RESTful API 提供了以下几种方法: