详解Kubernetes1.5新特性

Kubernetes是一个可移植的、可扩展的开源平台,用于管理容器化的工作负载和服务,可促进声明式配置和自动化。 Kubernetes 拥有一个庞大且快速增长的生态系统。Kubernetes 的服务、支持和工具广泛可用,本篇文章重点为大家讲解一下Kubernetes1.5新特性。

主题简介

1、StatefulSets (原名PetSets)

StatefulSets 现在是 beta 版 (主要是修复和稳定性)

2、改善联邦支持

新命令:kubefed
DaemonSets

部署
Configmaps

3、简化集群部署

改进kubeadm

Master的HA设置

4、节点鲁棒性及可扩展性

支持Windows Service容器

实现了CRI(容器运行时接口)

添加kubelet API调用时身份验证和授权

新特性简介

1、API 机制

[beta] kube-apiserver支持OpenAPI从alpha移动到beta, 第一个non-go客户端是基于此特性。

2、应用

[Stable]当replica sets不能创建Pods时,它们将通过API报告失败的详细底层原因。
[Stable] kubectl apply现可通过–prune删除不再需要的资源
[beta] Deployments现可通过API升级到新版本,而之前是无法通过滚动来进行升级的
[beta] StatefulSets允许要求持久化identity或单实例存储的工作负载从而在Kubernetes创建和管理。
[beta]为了提供安全保障,集群不会强行删除未响应节点上的Pods,如果用户通过CLI强行删除Pods会收到警告。

3、认证

[Alpha]改进了基于角色的访问控制alpha API。(包括一组默认的集群角色)
[Beta]添加了对Kubelet API访问的认证/授权机制。

4、AWS

[stable]角色出现在kubectl get nodes的结果里。

5、集群生命周期

[alpha] 提升了kubeadm二进制包的交互和可用性,从而更易于新建一个运行集群。

6、集群运维

[alpha] 在GCE上使用kube-up/kube-down脚本来创建/移除集群高可用(复制)的主节点。

7、联邦

[beta] 支持联邦ConfigMaps。
[alpha] 支持联邦Daemonsets。
[alpha] 支持联邦Deployments。
[alpha]集群联邦:为联邦资源添加对于DeleteOptions.OrphanDependents的支持。
[alpha]引入新命令行工具:kubefed,简化联邦控制台的部署以及集群注册/注销体验。

8、网络

[stable]服务可以通过DNS名称被其他服务引用,而不是只有在pods里才可以。
[beta]为NodePort类型和LoadBalancer的服务保留源IP的选项。
[stable]启用beta ConfigMap参数支持的DNS水平自动伸缩

9、节点

[alpha]支持在容器运行时启用用户命名空间重映射的时候,保留对宿主用户命名空间的访问。
[alpha]引入了v1alpha1版本的CRI(容器运行时接口) API,它允许可插拔的容器运行时;现有一个已经就绪的用于测试和反馈的docker-CRI集成。
[alpha]Kubelet基于QoS层在每个Pod的CGroup层级里启动容器。
[beta]Kubelet集成了memcg提示消息API,来检测是否超过阈值。
[beta]引入了Beta版本的容器化节点一致性测试: gcr.io/google_containers/node-test:0.2。从而让用户验证node设置。

10、调度

[alpha]添加了对不透明整数资源(node级)的审计支持。
[beta] PodDisruptionBudget已经升级到Beta版,当想要应用SLO时,可以用来安全地drain节点。

11、UI

[stable]Dashboard UI如今显示面向用户的对象及它们的资源使用情况。

12、Windows

[alpha]添加了对Windows Server 2016节点和调度Windows Server Container的支持。

已知问题

CRI已知问题及限制。

当volume路径包含空格时,DeviceNameFromMount()函数不能正确的返回volume路径。

联邦alpha版的特性不具有特征定义,因此默认启用,在未来的版本中将修复这一问题。

联邦控制面板可通过更新控制面板组件Deployment规格的镜像字段来进行升级,然而在该版本中联邦控制面板升级尚未进行测试。

重大改变

1、节点控制器不再强行删除来源于apiServer的pods

对于有状态的应用StatefulSet(原名为 PetSet)而言,这个改动意味着创建替换的Pods被阻塞,直到旧的Pods确定不再运行(意味着kubelet从分区返回,Node对象的删除,云服务商里实例的删除,或强行删除api-Server里的Pod)。这里通过确保不可达的Pod不会被认为已经死亡来防止集群应用出现“脑裂”的状况,除非一些“包围”操作提供了上述之一的情况。

对于其他现有的除StatefulSet外的控制器,这对于控制器替换Pods没有影响,因为控制器不会重用Pods名称(他们使用generate-name)用户编写的控制器会重用Pod对象的名称,应该考虑这个变化。

当使用kubectl delete … –grace-period=0 删除一个对象时,客户端将开始进行优雅的删除并等待,直到资源完全被删除。要立即强制删除,使用–force 标志。这可以防止用户不小心让两个Stateful Set共享可能导致数据损坏的相同的持久存储。

2、允许匿名API服务器的访问,通过授权组系统设置认证的用户

kube-apiserver添加了–anonymous-auth 标志,默认为true。当它启用时,访问安全端口的请求不会被其他配置的认证方法所拒绝,这些请求被当做匿名请求,并且用户名为system:anonymous,组织为system:unauthenticated。 认证的用户被设为system:authenticated组。

3、即使路径是用于类型的有效字段,如果路径在json文件下不提供字段,kubectl get -o jsonpath=… 将抛出一个错误。这个改变从pre-1.5版本开始,即使他们目前不在 json文件下,也会返回一些字段的默认值。

4、对于VolumeMounts的strategicmerge patchMergeKey是由“名称”到“mountPath”的改变。这是必要的,因为名称字段引用Volume的名称,并且不是VolumeMount的唯一键。如果安装多个相同的volume,多个VolumeMounts将有同样的 Volume名称。“mountPath”是独一无二的,并可以作为mergekey。

升级前注意事项

1、升级前重要的安全相关改变 必须在kube-apiserver设置–anonymous-auth=false参数,除非你是一个测试该功能的开发者并且了解它。如果不这样,你会允许未经授权的用户访问你的apiserver。

必须在联邦apiserver设置–anonymous-auth=false参数,除非你是一个测试该功能的开发者并且了解它。如果不这样,你会允许未经授权的用户访问你的联邦apiserver。你不需要调整kublete的该参数:1.4的Kubelet APIs没有授权。

2、batch/v2alpha1.ScheduledJob被重命名为batch/v2alpha1.CronJob。

3、PetSet被重命名为StatefulSet。如果你现在有PetSets,你要在升级为StatefulSets前后进行一些额外的迁移操作。

4、如果你从v1.4.x升级你的集群联邦组件,请更新你的federation-apiserver和federation-controller-manager到新版本。

5、废弃的kubelet –configure-cbr0参数被移除。经典的网络模式也是。如果你依赖于此模式,请调研其他的网络插件kubenet或cni是否满足需求。

6、新的client-go结构,参考kubernetes/client-go进行版本控制策略。

7、废弃的kube-scheduler –bind-pods-qps和–bind-pods burst参数被移除,替换为–kube-api-qps和–kube-api-burst。

8、如果你需要使用1.4的特性:PodDisruptionBudget(例如创建了PodDisruptionBudget对象),那么在从1.4升级为1.5之前,你一定要删除所有创建的PodDisruptionBudget对象(policy/v1alpha1/PodDisruptionBudget)。升级之后不可能删除这些对象。它们的存在也会妨碍你使用1.5里Beta版的PodDisruptionBudget特性(policy/v1beta1/PodDisruptionBudget)。如果你已经进行了升级,那么你需要降级到1.4来删除这policy/v1alpha1/PodDisruptionBudget对象。

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/202985.html<

(0)
运维的头像运维
上一篇2025-04-06 11:41
下一篇 2025-04-06 11:42

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注