K8S 生态周报| Kubernetes v1.19 正式发布

2024-03-17 00:48

本文主要是介绍K8S 生态周报| Kubernetes v1.19 正式发布,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

「K8S 生态周报」内容主要包含我所接触到的 K8S 生态相关的每周值得推荐的一些信息。欢迎订阅知乎专栏「k8s生态」[1]

Kubernetes v1.19 正式发布

本周 Kubernetes v1.19 正式发布,这是今年发布的第二个版本,也是耗时最长的一个版本。

在此版本中有 34 个增强功能,其中 10 个GA,15 个 beta 以及 9 个 alpha。并且从 v1.19 开始,Kubernetes 每个版本的支持周期延长至 1 年。(感谢[ Long Term Support (LTS) working group ](https://github.com/kubernetes/community/tree/master/wg-lts#readme "LTS WG"))

关于此版本中重要的变更,可参考我每期周报中 “上游进展” 的部分。或者直接参考 官方博客中 v1.19 的介绍文章[2]

这里我来单独介绍一个更具体且实用的特性。

API 弃用规则

Kubernetes 是一个庞大的系统,当讨论它的 API 时,我们不得不提到常用的 4 个术语,即:group(组), version(版本), kind(类型)和 resource(资源)。

一个 API group 是一组相关功能的集合,group + version 是确保 API 可随着时间推移,进行版本升级或功能更新的基础。

这里我来介绍下 自 Kubernetes v1.19 开始 针对 REST 资源(aka API 对象)在弃用策略相关的变更。

当请求一个已标记为废弃的 REST API endpoint 时,会有如下行为:

  • 根据 RFC7234 [3] 会返回一个 Warning header;

  • 添加一个 "k8s.io/deprecated":"true" annotation 到记录此次请求的 audit event 中;

  • kube-apiserver 进程设置一个类型为 Gauge 的 metric apiserver_requested_deprecated_apis 的值为 1。这个 metrics 有 group, version, resource, subresource 等标签。例如:

apiserver_requested_deprecated_apis{group="extensions",removed_release="1.22",resource="ingresses",subresource="",version="v1beta1"} 1

这表示 extensionsv1beta1 版本的 ingresses 资源将在 1.22 版本移除。

我们可以将这个指标和 apiserver_request_total 这个指标进行组合查询,即可看到当前集群中有多少请求是在访问已废弃 API 的。

例如使用如下查询条件,用来查询当前有多少请求将在 1.22 中移除的 API:

apiserver_requested_deprecated_apis{removed_release="1.22"} * on(group,version,resource,subresource) group_right() apiserver_request_total

K8S metrics - https://moelove.info

使用场景 不知道你是否还记得 v1.18 中删除了很多已废弃的 API 版本,在集群版本升级时,我们需要确保已经更新/删除使用这些 API 版本的资源,以免在集群升级后,导致已部署资源的异常。

当我们使用上面介绍的方法,直接组合 apiserver_requested_deprecated_apis 指标和 apiserver_request_total 指标进行查询,即可看到当前集群内是否有会受此影响的请求。

关于此版本的详细变更请参考 v1.19 的 ReleaseNote[4]

Prometheus 2.21.0-rc.0 发布

此版本使用 Go v1.15 构建,在 TLS 证书验证时,弃用了 X.509 CommonName[5] 的支持。

我们一起来看看此版本中值得注意的变更吧:

  • 新增的 Service Discovery:Eureka SD[6] 和 Hetzner SD[7];

  • Kubernetes SD 现在已支持 EndpointSlices[8]

  • 新增 target_limit 配置 ,表示每次抓取能接受的 instance 数量。在 target relabel 之后,如果超过了此配置,则 Prometheus 会将其标记为失败。这是一项实验性功能,后续行为可能会有调整;

  • #7713 在 PromQL 和 UI 中支持更易读的时间周期;

  • #7856 修复了 chunks.HeadReadWriter: maxt of the files are not set 的错误;

更多关于此版本的变更,请参考其 ReleaseNote[9]

jaeger v1.19 系列发布

本周连续发布了 v1.19.0 至 v1.19.2 版本,主要 bug 都集中在 UI 上。并且在 v1.19 中有一个已知的问题,#2297 是为 gRPC query 添加 TLS 支持,但未注册 flag ,所以此特性不能使用。计划是在 v1.20 中修复。

  • #2336 可配置的 UDP socket buffer size;

  • #2330 默认支持批量且队列化的重试;

上游进展

  • Kubernetes v1.16.15 将会是 Kubernetes v1.16 中的最后一个版本;


欢迎订阅我的文章公众号【MoeLove】

TheMoeLove

参考资料

[1]

k8s生态: https://zhuanlan.zhihu.com/container

[2]

v1.19 介绍: https://kubernetes.io/blog/2020/08/26/kubernetes-release-1.19-accentuate-the-paw-sitive/

[3]

RFC7234: https://tools.ietf.org/html/rfc7234#p-5.5

[4]

v1.19 ReleaseNote: https://github.com/kubernetes/kubernetes/blob/master/CHANGELOG/CHANGELOG-1.19.md

[5]

X.509 CommonName: https://golang.org/doc/go1.15#commonname

[6]

Eureka SD: https://github.com/prometheus/prometheus/pull/3369

[7]

Hetzner SD: https://github.com/prometheus/prometheus/pull/7822

[8]

Kubernetes SD 支持 EndpointSlices: https://github.com/prometheus/prometheus/pull/6838

[9]

Prometheus v2.21.0-rc.0 ReleaseNote: https://github.com/prometheus/prometheus/releases/tag/v2.21.0-rc.0

这篇关于K8S 生态周报| Kubernetes v1.19 正式发布的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/817300

相关文章

macOS Sequoia 15.5 发布: 改进邮件和屏幕使用时间功能

《macOSSequoia15.5发布:改进邮件和屏幕使用时间功能》经过常规Beta测试后,新的macOSSequoia15.5现已公开发布,但重要的新功能将被保留到WWDC和... MACOS Sequoia 15.5 正式发布!本次更新为 Mac 用户带来了一系列功能强化、错误修复和安全性提升,进一步增

Maven 依赖发布与仓库治理的过程解析

《Maven依赖发布与仓库治理的过程解析》:本文主要介绍Maven依赖发布与仓库治理的过程解析,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下... 目录Maven 依赖发布与仓库治理引言第一章:distributionManagement配置的工程化实践1

使用Python构建一个Hexo博客发布工具

《使用Python构建一个Hexo博客发布工具》虽然Hexo的命令行工具非常强大,但对于日常的博客撰写和发布过程,我总觉得缺少一个直观的图形界面来简化操作,下面我们就来看看如何使用Python构建一个... 目录引言Hexo博客系统简介设计需求技术选择代码实现主框架界面设计核心功能实现1. 发布文章2. 加

售价599元起! 华为路由器X1/Pro发布 配置与区别一览

《售价599元起!华为路由器X1/Pro发布配置与区别一览》华为路由器X1/Pro发布,有朋友留言问华为路由X1和X1Pro怎么选择,关于这个问题,本期图文将对这二款路由器做了期参数对比,大家看... 华为路由 X1 系列已经正式发布并开启预售,将在 4 月 25 日 10:08 正式开售,两款产品分别为华

利用Python快速搭建Markdown笔记发布系统

《利用Python快速搭建Markdown笔记发布系统》这篇文章主要为大家详细介绍了使用Python生态的成熟工具,在30分钟内搭建一个支持Markdown渲染、分类标签、全文搜索的私有化知识发布系统... 目录引言:为什么要自建知识博客一、技术选型:极简主义开发栈二、系统架构设计三、核心代码实现(分步解析

微信公众号脚本-获取热搜自动新建草稿并发布文章

《微信公众号脚本-获取热搜自动新建草稿并发布文章》本来想写一个自动化发布微信公众号的小绿书的脚本,但是微信公众号官网没有小绿书的接口,那就写一个获取热搜微信普通文章的脚本吧,:本文主要介绍微信公众... 目录介绍思路前期准备环境要求获取接口token获取热搜获取热搜数据下载热搜图片给图片加上标题文字上传图片

SpringKafka消息发布之KafkaTemplate与事务支持功能

《SpringKafka消息发布之KafkaTemplate与事务支持功能》通过本文介绍的基本用法、序列化选项、事务支持、错误处理和性能优化技术,开发者可以构建高效可靠的Kafka消息发布系统,事务支... 目录引言一、KafkaTemplate基础二、消息序列化三、事务支持机制四、错误处理与重试五、性能优

新特性抢先看! Ubuntu 25.04 Beta 发布:Linux 6.14 内核

《新特性抢先看!Ubuntu25.04Beta发布:Linux6.14内核》Canonical公司近日发布了Ubuntu25.04Beta版,这一版本被赋予了一个活泼的代号——“Plu... Canonical 昨日(3 月 27 日)放出了 Beta 版 Ubuntu 25.04 系统镜像,代号“Pluc

Nginx实现前端灰度发布

《Nginx实现前端灰度发布》灰度发布是一种重要的策略,它允许我们在不影响所有用户的情况下,逐步推出新功能或更新,通过灰度发布,我们可以测试新版本的稳定性和性能,下面就来介绍一下前端灰度发布的使用,感... 目录前言一、基于权重的流量分配二、基于 Cookie 的分流三、基于请求头的分流四、基于请求参数的分

定价129元!支持双频 Wi-Fi 5的华为AX1路由器发布

《定价129元!支持双频Wi-Fi5的华为AX1路由器发布》华为上周推出了其最新的入门级Wi-Fi5路由器——华为路由AX1,建议零售价129元,这款路由器配置如何?详细请看下文介... 华为 Wi-Fi 5 路由 AX1 已正式开售,新品支持双频 1200 兆、配有四个千兆网口、提供可视化智能诊断功能,建