コンテンツにスキップ

クライアントパッケージ@開発

はじめに

本サイトにつきまして、以下をご認識のほど宜しくお願いいたします。


01. client-go

client-goとは

Kubernetesのkube-apiserverと通信できるパッケージ。

使用できるAPIの型を拡張するために、k8s.io/api パッケージや k8s.io/apimachinery パッケージも必要になる。


セットアップ

kube-apiserverの認証/認可を通過するために、kubeconfig ファイルをコンテナにマウントする必要がある。


client-goパッケージとkube-apiserverのバージョン整合性

▼ client-goパッケージとkube-apiserverの間

kubectl コマンドとkube-apiserverのバージョンの整合性と同様にして、client-goパッケージにもkube-apiserverのバージョンと整合性がある。

例えば、client-goパッケージの 0.20.4 は、kube-apiserverの v1.20.4 をサポートしている。

We recommend using the v0.x.y tags for Kubernetes releases >= v1.17.0 and kubernetes-1.x.y tags for Kubernetes releases < v1.17.0.

kube-apiserverとクライアント側のバージョン差は、前方/後方の 1 個のマイナーバージョン以内に収めることが推奨されており、client-goパッケージにもこのポリシーが適用される。

そのため、client-goパッケージを定期的にアップグレードする必要がある。

▼ client-goパッケージとマニフェストの間

Kubernetesのマニフェストには .apiVersion キーが定義されている。

kube-apiserverのバージョンに応じて、公式リポジトリが用意するマニフェストにて、.apiVersion キーが v1 から v2 になることがある。

この場合、client-goパッケージがこの .apiVersion キーをサポートしていないと、kube-apiserverにそのマニフェストを送信できない。

反対に、マニフェストですでに廃止済みの .apiVersion キーが指定されていて、client-goパッケージでもこれが廃止されていても、同様のことが起こる。

そのため、client-goパッケージを定期的にアップグレードする必要がある。

▼ 調査例

ArgoCDの 2.3.0 では、client-goパッケージのバージョンが 0.23.1 であった。

このことから、ArgoCDは 2.3.0 がKubernetesの 1.23.1 で稼働できることがわかる。

なお、デプロイ先のClusterとしていずれのバージョンをサポートしているかは、gitops-engine パッケージを確認する必要がある。

Kubernetesの 1.23.1 がサポートしているAPIグループのバージョンから、マニフェストで使用できる .apiVersion がわかる。