K8S的apiVersion

本篇文章来自Terraform与Kubernetes中关于Deployment apps/v1的吐槽

原文链接:https://segmentfault.com/a/1190000017134399

说明

在1.11版本中,推荐为 apps/v1 具体由以下版本:

apps/v1 
apps/v1beta1
apps/v1beta2

v1支持的资源类型有:

Binding,ComponentStatus,ConfigMap,Endpoints,Event,LimitRange,Namespace,
Node,pvc,pv,pods,podtemplates,Binding,Eviction,ReplicationController,
Scale,ReplicationController,ResourceQuota,Secret,ServiceAccount,Service

apps/v1支持的资源类型有:

DaemonSet,ControllerRevision,Deployment,Scale,ReplicaSet,StatefulSet

extensions/v1beta1支持的资源类型有:

DaemonSet,Deployment,DeploymentRollback,Scale,Ingress,NetworkPolicy,
PodSecurityPolicy,ReplicaSet,ReplicationControllerDummy

Kubernetes的官方文档中并没有对apiVersion的详细解释,而且因为K8S本身版本也在快速迭代,有些资源在低版本还在beta阶段,到了高版本就变成了stable。

如Deployment:

1.6版本之前 apiVsersion:extensions/v1beta1

1.6版本到1.9版本之间:apps/v1beta1

1.9版本之后:apps/v1

一.各种apiVersion的含义

alpha

* 该软件可能包含错误。启用一个功能可能会导致bug
* 随时可能会丢弃对该功能的支持,恕不另行通知

beta

* 软件经过很好的测试。启用功能被认为是安全的。
* 默认情况下功能是开启的
* 细节可能会改变,但功能在后续版本不会被删除

stable

* 该版本名称命名方式:vX这里X是一个整数
* 稳定版本、放心使用
* 将出现在后续发布的软件版本中

v1

Kubernetes API的稳定版本,包含很多核心对象:pod、service等

apps/v1beta2

在kubernetes1.8版本中,新增加了apps/v1beta2的概念,apps/v1beta1同理
DaemonSet,Deployment,ReplicaSet 和 StatefulSet的当时版本迁入apps/v1beta2,兼容原有的extensions/v1beta1

apps/v1

在kubernetes1.9版本中,引入apps/v1,deployment等资源从extensions/v1beta1, apps/v1beta1 和 apps/v1beta2迁入apps/v1,原来的v1beta1等被废弃。

apps/v1代表:包含一些通用的应用层的api组合,如:Deployments, RollingUpdates, and ReplicaSets

batch/v1

代表job相关的api组合

在kubernetes1.8版本中,新增了batch/v1beta1,后CronJob 已经迁移到了 batch/v1beta1,然后再迁入batch/v1

autoscaling/v1

代表自动扩缩容的api组合,kubernetes1.8版本中引入。
这个组合中后续的alpha 和 beta版本将支持基于memory使用量、其他监控指标进行扩缩容

extensions/v1beta1

deployment等资源在1.6版本时放在这个版本中,后迁入到apps/v1beta2,再到apps/v1中统一管理

certificates.k8s.io/v1beta1

安全认证相关的api组合

authentication.k8s.io/v1

资源鉴权相关的api组合

二.查看当前可用的API版本

执行 kubectl api-versions

kubernetes 1.8

apiextensions.k8s.io/v1beta1
apiregistration.k8s.io/v1beta1
apps/v1beta1
apps/v1beta2
authentication.k8s.io/v1
authentication.k8s.io/v1beta1
authorization.k8s.io/v1
authorization.k8s.io/v1beta1
autoscaling/v1
autoscaling/v2beta1
batch/v1
batch/v1beta1
certificates.k8s.io/v1beta1
extensions/v1beta1
networking.k8s.io/v1
policy/v1beta1
rbac.authorization.k8s.io/v1
rbac.authorization.k8s.io/v1beta1
settings.k8s.io/v1alpha1
storage.k8s.io/v1
storage.k8s.io/v1beta1
v1

kubernetes 1.11

admissionregistration.k8s.io/v1alpha1
admissionregistration.k8s.io/v1beta1
apiextensions.k8s.io/v1beta1
apiregistration.k8s.io/v1
apiregistration.k8s.io/v1beta1
apps/v1
apps/v1beta1
apps/v1beta2
authentication.k8s.io/v1
authentication.k8s.io/v1beta1
authorization.k8s.io/v1
authorization.k8s.io/v1beta1
autoscaling/v1
autoscaling/v2beta1
batch/v1
batch/v1beta1
certificates.k8s.io/v1beta1
events.k8s.io/v1beta1
extensions/v1beta1
networking.k8s.io/v1
policy/v1beta1
rbac.authorization.k8s.io/v1
rbac.authorization.k8s.io/v1beta1
scheduling.k8s.io/v1beta1
settings.k8s.io/v1alpha1
storage.k8s.io/v1
storage.k8s.io/v1alpha1
storage.k8s.io/v1beta1
v1

三.检索api的详细信息

查看完整路径

curl https://192.168.1.209:6443 --cacert /etc/kubernetes/pki/ca.pem --cert /etc/kubernetes/pki/admin-192.168.1.209.pem --key /etc/kubernetes/pki/admin-192.168.1.209-key.pem

查看apps/v1的信息

curl https://192.168.1.209:6443/apis/apps/v1 --cacert /etc/kubernetes/pki/ca.pem --cert /etc/kubernetes/pki/admin-192.168.1.209.pem --key /etc/kubernetes/pki/admin-192.168.1.209-key.pem

查看v1的信息

curl https://192.168.1.209:6443/api/v1 --cacert /etc/kubernetes/pki/ca.pem --cert /etc/kubernetes/pki/admin-192.168.1.209.pem --key /etc/kubernetes/pki/admin-192.168.1.209-key.pem

参考文章

https://matthewpalmer.net/kubernetes-app-developer/articles/kubernetes-apiversion-definition-guide.html

Last updated