本文由张磊、心贵、临石、徙远、衷源、浔鸣等同窗联合撰写。linux
Kubernetes 1.14.0 Release 已经于 3 月 25 日正式发布。相信你也已经注意到,相比于1.13 和 1.12 版本,此次发布包含的重要变很是多,其对应的 Release Note 的篇幅长度也创下了“新高”。git
面对这样一份“海量信息”的 Release Note,咱们该如何从这份文档里进行高效的信息过滤和挖掘,帮助团队更精准、快速的梳理出此次发布最主要的技术脉络呢?github
在本篇文章中,咱们将 1.14 的Release Note 按照主题进行了从新概括和梳理,按照类别对重要变动进行了技术剖析和讨论。但愿这种“分类解读”的方式,可以帮助你们更好的理解 1.14 这个发布的核心内容。数据库
随着1.14的发布,Kubernetes 对windows节点的生产级支持无疑是一个重要的里程碑。具体来讲,1.14 版本针对 Windows 作了大量加强;windows
而伴随着 Windows 容器的生态正在慢慢壮大,可以在生产级别支持 Windows 节点的容器服务开始见诸各大云厂商。阿里云容器服务(ACK)近期已经推出了 Windows Container 的支持,提供了 linux/windows 应用混合部署的统一管理能力。网络
参见:Support for Windows Nodes is Graduating to Stable (#116 )架构
长期以来,可以让 Kubernetes 直接用宿主机的本地存储设备(好比:本地 SSD 硬盘)来提供持久化数据卷(即:Local PV 功能),一直是社区里很是强烈的一个诉求。这个缘由很容易理解:相对于远程存储(网络存储),Local PV 在时延性、易用性、稳定性和费用上具备独特的优点,尤为是对于相关特性比较敏感的应用,如数据库应用和搜索引擎应用来讲,有着重要的意义。less
而在 1.14 中,Local PV 终于正式宣布 GA,为云上的持久化存储选择增长了一种重要的的可能。运维
不过,必需要明确的是, 选择使用 Local PV,也意味着用户必须本身承担一些潜在的风险,这包括:分布式
第一个问题,能够经过好比阿里云的 local-volume-provisioner 实现本地 SSD Nvme 实例自动建立数据卷来解决,但对于容错性和健壮性的问题,就是比较棘手的了。
参见:Durable Local Storage Management is Now GA (#121)
Kubernetes 里的任务优先级(priority)和抢占机制(preemption)的目的十分明确:保证高优先级的任务能够在须要的时候经过抢占低优先级任务的方式获得运行。
这其中,优先级定义了一个 Pod 在集群中的重要程度,这个重要程度体现且仅体如今两个地方:
(1)高优先级的Pod 在调度阶段更容易被优先调度(K8s 采用队列调度模型),注意这里并不保证高优先级 Pod 永远被优先调度,实际影响调度顺序的因素有不少;
(2)在集群总体负载较高时,若是出现高优先级 Pod 没法被调度的状况(集群中没有知足条件的 Node 供 Pod 运行),K8s 会启动抢占机制,经过抢占已经运行的低优先级的 Pod 的方式,让高优先级的 Pod 能够运行起来。抢占机制即是在这里引入的。
抢占机制指当调度器发现某个Pod(如 Pod-A)没法在集群中找到合适的节点部署时(全部节点 Predicates 所有失败),会试图经过删除一些优先级低于 Pod-A 的 Pod 来“腾出空间”部署 Pod-A,这样 Pod-A 就能够被调度了。这样一个“看似简单”的需求在分布式环境中实施起来有不少细节,例如:如何决定删除哪一个节点的哪些 Pod、如何保证为 Pod-A 腾出的空间不被其它 Pod 占用、如何保证 Pod-A 不被饿死(Starvation)、如何处理有亲和性需求的 Pod 调度约束、是否须要支持跨节点 Preemption 以支持某些特定的约束(例如某 Failure Domain 的反亲和约束)等等。
参见:Pod Priority and Preemption in Kubernetes (#564)
在 1.14 版本以前,Kubernetes 判断一个 Pod 是否 Ready,就是检查这个 Pod 的容器是否所有正常运行。可是这里有个问题,那就是容器或者说里面的主进程 Ready,并不必定意味着这个应用副本就必定是就绪的。为了确认 Pod 确实能够正常可用,咱们但愿给它增长一些外部指标(好比,该 Pod 须要的 Service,DNS,存储等服务所有就绪),来反应这个Pod是否“真正”Ready。
这个特性,就是1.14 里一个叫作“Pod Readiness Gates”、也叫作 Pod Ready ++ 的特性。它为pod的“Ready 状态” 提供了一个很是强大的扩展点。须要注意的是,用户须要编写一个外部控制器(Controller)来为这个Pod Readiness Gates 字段对应的指标设置值。
参见:Pod Ready++ (#580)
1.14以后,Kubernetes 项目自己开始具有了原生的应用管理能力,这其中最重要的一个功能,就是 Kustomize。
Kustomize 容许用户从一个基础 YAML 文件,经过 overlay 的方式生成最终部署应用所需的 YAML 文件,而不是像 Helm 那样经过字符串替换的方式来直接修改基础 YAML 文件(模板)。这样,在一个用户经过 overlay 生成新的 YAML 文件的同时,其余用户能够彻底不受影响的使用任何一个基础 YAML 或者某一层生成出来的 YAML 。这使得每个用户,均可以经过 fork/modify/rebase 这样 Git 风格的流程来管理海量的 YAML 文件。这种 PATCH 的思想跟 Docker 镜像是很是相似的,它既规避了“字符串替换”对 YAML 文件的入侵,也不须要用户学习蹩脚的 DSL 语法(好比 Lua)。
在1.14以后,Kustomize 已经成为了 kubectl 的一个内置命令。不难看到,Kubernetes 社区正在探索一种 Helm 以外的、更加 Kubernetes 原生的应用管理方法。具体效果如何,咱们不妨拭目以待。
参见:Added Kustomize as a subcommand in kubectl (#73033, @Liujingfang1)
随着你们对 Kubernetes 愈来愈熟悉,对 kubectl 依赖也愈来愈强烈,需求也愈来愈多样化。而在 1.14 中,kubectl 着重在如下几个方面,提高用户体验,增强对平常运维能力的支持。
kubectl auth can-i --list --namespace=ns1
来查看本身在 ns1 这个 namespace 下能够访问哪些资源 (好比 Pod,Service 等),并有哪些操做的权限(好比 Get,List,Patch,Delete 等)了。kubectl delete xxx --all-n
amespaces
来进行统一的删除操做了(这里 XXX 能够是 Pod,Services,Deployment,自定义的 CRD 等等),而且还能够配合 -l
和 --field-selector
能够更精确地删除知足特定条件的资源。和以前每一个版本同样,Kubernetes 的新版本发布对稳定性和可靠性加强的关注一直是重中之重,下面咱们列举出一些值得注意的修复和升级。
在 Kubernetes 的主干功能日趋稳定以后,社区已经开始更多的关注大规模场景下 Kubernetes 项目会暴露出来的各类各样的问题。在 v1.14 中,Kubernetes 社区从面向最终用户的角度作出了不少优化,好比:
#72641:github.com/kubernetes/…
#64820:github.com/kubernetes/…
#73716:github.com/kubernetes/…
#72730:github.com/kubernetes/…
#73802:github.com/kubernetes/…
#74389:github.com/kubernetes/…
#72709:github.com/kubernetes/…
#73345:github.com/kubernetes/…
#74000:github.com/kubernetes/…
#71223:github.com/kubernetes/…
公众号:金融级分布式架构(Antfin_SOFA)