K8S 生态周报| Google 选择 Cilium 作为 GKE 下一代数据面

2023-10-08 00:59

本文主要是介绍K8S 生态周报| Google 选择 Cilium 作为 GKE 下一代数据面,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

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

Google 选择 Cilium 作为 GKE 网络的数据面

GKE & Cilium

Google 声明[2]将选择 Cilium[3] 作为 GKE 网络的数据面 V2 以便增加其容器安全性和可观测性。

Kubernetes 最强的能力之一便是其开发者优先的网络模型,可以提供简单易用的功能,比如:L3/L4 service 和 L7 ingress 以便将流量引入 Kubernetes 集群,以及多租户的网络隔离等。

但随着越来越多的企业使用 Kubernetes , 用例范围越来越广,围绕多云,安全性,可观察性和可扩展性等方面均提出了新的要求。此外,诸如 service mesh 和 serverless 等技术,均需要来自底层 Kubernetes 的更多自定义。这些新要求最终汇聚到一起得出来的结论便是:需要一个更具可编程性的数据平面,该平面可执行 Kubernetes 感知的数据包操作,并且还不会损失性能。

Cilium 的出现恰恰满足了这些需求,它基于 eBPF 技术的实现,使 Linux 内核具备了 Kubernetes 的意识。它可以很好的满足现在新的对容器负载的可伸缩性,可观察性以及安全等方面相关的要求。此外, Cilium 所提供的功能也远超了传统 CNI 提供的功能,不仅有传统的 Network Policy, service 和 LB ,还有 Flow & Policy logging 以及内置运维和安全侧的 metrics 等。

背后的故事

Google 首次参与 Cilium 项目大概是去年 12 月,后来越来越多的 Google 工程师加入进来,也贡献了很多核心功能,比如上文中提到的 Policy Logging 等功能。此外还有很多,比如自动检测 EndpointSlices ,对 Pod IP 的 IPv6 邻居发现的支持,还有基于 socket cookie 的负载均衡等。

当然,Google 是有实力可以直接基于 eBPF 来构建其数据平面的,但它选择了参与 Cilium 社区,这也是对 Cilium 社区多年来工作的认可,这也让社区成员非常开心。

相信今后将会有更多有趣的特性被加入进来。

以下是 Cilium 主要的功能:

Cilium 核心功能 - https://moelove.info

在去年 8 月份的 《K8S 生态周报| cilium 1.6 发布 100% kube-proxy 的替代品》[4] 一文中,我就曾介绍过 Cilium 项目及其所用技术,也针对该项目写了自己的看法,感兴趣的朋友可以看看。

另外一个比较有意思的信息是,2017 年 Google 与 Calico 背后的公司 Tigera 合作,为 GKE 引入了 Calico 。Cilium 是否会取代 Calico 呢?

最后,如果你想要在 GKE 中使用 Cilium ,可以使用如下命令:

gcloud beta container clusters create <cluster name> \--enable-dataplane-v2 --release-channel rapid \--cluster-version 1.17.9-gke.600 --zone <zone name>

containerd v1.4.0 发布

本周 containerd 终于迎来了 v1.4.0 版本的正式发布,距离上一个正式大版本 v1.3.0 已经过去了近 10 个月,并且在正式发布之前,也先后经过了 3 个 beta 版本和 2 个 rc 版,可以看出此次发布还是很慎重的。

我在之前的 《K8S 生态周报| runc v1.0-rc92 发布》[5] 一文中,介绍过 containerd v1.4.0-rc.0 相关的内容,有兴趣的朋友可以结合着看。

以下是此 v1.4 中较为关键的特性:

  • 支持镜像的 lazy pull:

    • 主要适用场景:FaaS,Python/Ruby/Java/dotNet 等镜像环境;

    • 实现插件 stargz-snapshotter[6];

    • 基于 Stargz/CRFS 完成;

  • CRI 模式下支持 MCS 多类别的安全;

  • 添加 cgroup v2 的支持:

    • 支持 eBPF 集成;

    • 改善 OOM 控制;

  • 改善 rootless 模式的支持;

    • 资源控制需要 systemd 和 cgroup v2 的支持;

    • overlayfs snapshotter 可通过 FUSE-overlayfs 完成,需要 4.18 及以上内核;

  • 支持不重启 daemon 的情况下,重加载 CNI 配置;

更多关于此版本中的变更,请查看其 ReleaseNote[7]

Istio v1.7 正式发布

Istio v1.7 主要集中在易用性,安全性和可靠性上,并针对非 Kubernetes 环境做了一些优化。

在易用性方面,新版本中提供了 Istio 分析工具[8] 可通过 istioctl analyze --all-namespaces 使用;

在可靠性方面,你可以将应用程序的启动延迟到 sidecar 启动之后[9]

安全性方面,主要就是针对非 Kubernetes (VM) 环境的一些优化了。

感兴趣的朋友可以参考其 ReleaseNote[10]

k3s 成为了 CNCF sandbox 项目

k3s 目标是提供一种通过 CNCF 一致性认证的生产级 Kubernetes 发行版,但相比 Kubernetes 而言更加轻量和易于配置。主要受众目标是:

  • Edge

  • IoT

  • CI Pipeline

  • 开发到生产一致的环境

  • ARM 设备

它主要依赖的组件如下:

  • containerd 和 runc

  • Flannel

  • CoreDNS

  • CNI

  • Host utilities (iptables, socat, etc)

  • Ingress controller (traefik)

  • Embedded service loadbalancer

  • Embedded network policy controller

就我个人而言,我对 k3s 的了解&兴致仅限于它刚发布之时,后续偶尔会稍微看下相关的信息,但未在生产中使用过。

现在 k3s 的定位已经明确为 Kubernetes 的一种发行版,我觉得这个决定还是很明智的(相比 fork 而言)。之前听说国内有几个公司在搞 k3s on ARM 之类的,不过也没听到后续的结果,可能还是会面临一些问题吧。

生产使用我个人还是建议选择 Kubernetes 或者可选择 OpenShift 之类的。(有特殊场景或需求的另说)

题外话

以上便是我觉得本周值得关注的内容了,上周发起的“关于使用 Helm v2 or v3 ”的投票结果出来了, 参与投票的朋友中有 7 成在用 Helm v3

本期讨论内容:你在用哪个网络插件呢?以及选择它的原因 , 欢迎留言参与讨论!


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

TheMoeLove

参考资料

[1]

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

[2]

GKE 使用 Cilium 的声明: https://cloud.google.com/blog/products/containers-kubernetes/bringing-ebpf-and-cilium-to-google-kubernetes-engine

[3]

Cilium 主页: https://cilium.io/

[4]

cilium 1.6 发布: https://zhuanlan.zhihu.com/p/79757835

[5]

containerd v1.4.0-rc0 发布: https://zhuanlan.zhihu.com/p/178227659

[6]

stargz-snapshotter: https://github.com/containerd/stargz-snapshotter

[7]

containerd v1.4 release note: https://github.com/containerd/containerd/releases/tag/v1.4.0

[8]

Istio 分析工具: https://istio.io/latest/docs/ops/diagnostic-tools/istioctl-analyze/

[9]

istio 延迟启动: https://medium.com/@marko.luksa/delaying-application-start-until-sidecar-is-ready-2ec2d21a7b74

[10]

Istio v1.7: https://istio.io/latest/news/releases/1.7.x/announcing-1.7/

这篇关于K8S 生态周报| Google 选择 Cilium 作为 GKE 下一代数据面的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

大模型研发全揭秘:客服工单数据标注的完整攻略

在人工智能(AI)领域,数据标注是模型训练过程中至关重要的一步。无论你是新手还是有经验的从业者,掌握数据标注的技术细节和常见问题的解决方案都能为你的AI项目增添不少价值。在电信运营商的客服系统中,工单数据是客户问题和解决方案的重要记录。通过对这些工单数据进行有效标注,不仅能够帮助提升客服自动化系统的智能化水平,还能优化客户服务流程,提高客户满意度。本文将详细介绍如何在电信运营商客服工单的背景下进行

基于MySQL Binlog的Elasticsearch数据同步实践

一、为什么要做 随着马蜂窝的逐渐发展,我们的业务数据越来越多,单纯使用 MySQL 已经不能满足我们的数据查询需求,例如对于商品、订单等数据的多维度检索。 使用 Elasticsearch 存储业务数据可以很好的解决我们业务中的搜索需求。而数据进行异构存储后,随之而来的就是数据同步的问题。 二、现有方法及问题 对于数据同步,我们目前的解决方案是建立数据中间表。把需要检索的业务数据,统一放到一张M

关于数据埋点,你需要了解这些基本知识

产品汪每天都在和数据打交道,你知道数据来自哪里吗? 移动app端内的用户行为数据大多来自埋点,了解一些埋点知识,能和数据分析师、技术侃大山,参与到前期的数据采集,更重要是让最终的埋点数据能为我所用,否则可怜巴巴等上几个月是常有的事。   埋点类型 根据埋点方式,可以区分为: 手动埋点半自动埋点全自动埋点 秉承“任何事物都有两面性”的道理:自动程度高的,能解决通用统计,便于统一化管理,但个性化定

如何选择适合孤独症兄妹的学校?

在探索适合孤独症儿童教育的道路上,每一位家长都面临着前所未有的挑战与抉择。当这份责任落在拥有孤独症兄妹的家庭肩上时,选择一所能够同时满足两个孩子特殊需求的学校,更显得尤为关键。本文将探讨如何为这样的家庭做出明智的选择,并介绍星贝育园自闭症儿童寄宿制学校作为一个值得考虑的选项。 理解孤独症儿童的独特性 孤独症,这一复杂的神经发育障碍,影响着儿童的社交互动、沟通能力以及行为模式。对于拥有孤独症兄

使用SecondaryNameNode恢复NameNode的数据

1)需求: NameNode进程挂了并且存储的数据也丢失了,如何恢复NameNode 此种方式恢复的数据可能存在小部分数据的丢失。 2)故障模拟 (1)kill -9 NameNode进程 [lytfly@hadoop102 current]$ kill -9 19886 (2)删除NameNode存储的数据(/opt/module/hadoop-3.1.4/data/tmp/dfs/na

异构存储(冷热数据分离)

异构存储主要解决不同的数据,存储在不同类型的硬盘中,达到最佳性能的问题。 异构存储Shell操作 (1)查看当前有哪些存储策略可以用 [lytfly@hadoop102 hadoop-3.1.4]$ hdfs storagepolicies -listPolicies (2)为指定路径(数据存储目录)设置指定的存储策略 hdfs storagepolicies -setStoragePo

Hadoop集群数据均衡之磁盘间数据均衡

生产环境,由于硬盘空间不足,往往需要增加一块硬盘。刚加载的硬盘没有数据时,可以执行磁盘数据均衡命令。(Hadoop3.x新特性) plan后面带的节点的名字必须是已经存在的,并且是需要均衡的节点。 如果节点不存在,会报如下错误: 如果节点只有一个硬盘的话,不会创建均衡计划: (1)生成均衡计划 hdfs diskbalancer -plan hadoop102 (2)执行均衡计划 hd

从去中心化到智能化:Web3如何与AI共同塑造数字生态

在数字时代的演进中,Web3和人工智能(AI)正成为塑造未来互联网的两大核心力量。Web3的去中心化理念与AI的智能化技术,正相互交织,共同推动数字生态的变革。本文将探讨Web3与AI的融合如何改变数字世界,并展望这一新兴组合如何重塑我们的在线体验。 Web3的去中心化愿景 Web3代表了互联网的第三代发展,它基于去中心化的区块链技术,旨在创建一个开放、透明且用户主导的数字生态。不同于传统

【Prometheus】PromQL向量匹配实现不同标签的向量数据进行运算

✨✨ 欢迎大家来到景天科技苑✨✨ 🎈🎈 养成好习惯,先赞后看哦~🎈🎈 🏆 作者简介:景天科技苑 🏆《头衔》:大厂架构师,华为云开发者社区专家博主,阿里云开发者社区专家博主,CSDN全栈领域优质创作者,掘金优秀博主,51CTO博客专家等。 🏆《博客》:Python全栈,前后端开发,小程序开发,人工智能,js逆向,App逆向,网络系统安全,数据分析,Django,fastapi

C#实战|大乐透选号器[6]:实现实时显示已选择的红蓝球数量

哈喽,你好啊,我是雷工。 关于大乐透选号器在前面已经记录了5篇笔记,这是第6篇; 接下来实现实时显示当前选中红球数量,蓝球数量; 以下为练习笔记。 01 效果演示 当选择和取消选择红球或蓝球时,在对应的位置显示实时已选择的红球、蓝球的数量; 02 标签名称 分别设置Label标签名称为:lblRedCount、lblBlueCount