当前位置:首页 > 科技  > 软件

Kubernetes 外部 HTTP 请求到达 Pod 容器的全过程

来源: 责编: 时间:2024-01-02 09:26:53 318观看
导读Kubernetes 集群外部的 HTTP/HTTPS 请求是如何达到 Pod 中的 container 的?HTTP 请求流转过程概述如上图所示,全过程大致为:(1) 用户从 web/mobile/pc 等客户端发出 HTTP/HTTPS 请求。(2) 由于应用服务通常是通过域名的

Kubernetes 集群外部的 HTTP/HTTPS 请求是如何达到 Pod 中的 container 的?coT28资讯网——每日最新资讯28at.com

HTTP 请求流转过程概述

coT28资讯网——每日最新资讯28at.com

如上图所示,全过程大致为:coT28资讯网——每日最新资讯28at.com

(1) 用户从 web/mobile/pc 等客户端发出 HTTP/HTTPS 请求。coT28资讯网——每日最新资讯28at.com

(2) 由于应用服务通常是通过域名的形式对外暴露,所以请求将会先进行 DNS 域名解析,得到对应的公网 IP 地址。coT28资讯网——每日最新资讯28at.com

(3) 公网 IP 地址通常会绑定一个 Load Balancer 负载均衡器,此时请求会进入此负载均衡器。coT28资讯网——每日最新资讯28at.com

  • Load Balancer 负载均衡器可以是硬件,也可以是软件,它通常会保持稳定(固定的公网 IP 地址),因为如果切换 IP 地址会因为 DNS 缓存的原因导致服务某段时间内不可达。
  • Load Balancer 负载均衡器是一个重要的中间层,对外承接公网流量,对内进行流量的管理和转发。

(4) Load Balancer 再将请求转发到 kubernetes 集群的某个流量入口点,通常是 ingress。coT28资讯网——每日最新资讯28at.com

  • ingress 负责集群内部的路由转发,可以看成是集群内部的网关。
  • ingress 只是配置,具体进行流量转发的是 ingress-controller,后者有多种选择,比如 Nginx、HAProxy、Traefik、Kong 等等。

(5)  ingress 根据用户自定义的路由规则进一步转发到 service。coT28资讯网——每日最新资讯28at.com

  • 比如根据请求的 path 路径或 host 做转发。

coT28资讯网——每日最新资讯28at.com

coT28资讯网——每日最新资讯28at.com

(6) service 根据 selector(匹配 label 标签)将请求转发到 pod。coT28资讯网——每日最新资讯28at.com

  • service 有多种类型,集群内部最常用的类型就是 ClusterIP。
  • service 本质上也只是一种配置,这种配置最终会作用到 node 节点上的 kube-proxy 组件,后者会通过设置 iptables/ipvs 来完成实际的请求转发。
  • service 可能会对应多个 pod,但最终请求只会被随机转发到一个 pod 上。

(7) pod 最后将请求发送给其中的 container 容器。coT28资讯网——每日最新资讯28at.com

同一个 pod 内部可能有多个 container,但是多个容器不能共用同一个端口,因此这里会根据具体的端口号将请求发给对应的 container。coT28资讯网——每日最新资讯28at.com

以上就是一种典型的集群外部 HTTP 请求如何达到 Pod 中的 container 的全过程。coT28资讯网——每日最新资讯28at.com

需要注意的是,由于网络配置灵活多变,以上请求流转过程并不是唯一的方式,例如:coT28资讯网——每日最新资讯28at.com

如果你使用的是云服务,那么可以通过使用 LoadBalancer 类型的 service 直接绑定一个云服务商提供的负载均衡器,然后再接 ingress 或者其它 service。coT28资讯网——每日最新资讯28at.com

你也可以通过 NodePort 类型的 service 直接使用节点上的端口,通过这些节点自建负载均衡器。coT28资讯网——每日最新资讯28at.com

如果你的服务特别简单,没啥内部流量需要管理的,这时不用 ingress 也是可以的。coT28资讯网——每日最新资讯28at.com

容器技术的底座

容器技术的底座有三样东西:coT28资讯网——每日最新资讯28at.com

  • Namespace(这里是指 Linux 系统内核的命名空间)
  • Cgroups
  • UnionFS

正是 Linux 内核的 namespace 实现了资源的隔离。因为每个 pod 有各自的 Linux namespace,所以不同的 pod 是资源隔离的。namespace 有多种,包括 PID、IPC、Network、Mount、Time 等等。其中 PID namespace 实现了进程的隔离,因此 pod 内可以有自己的 1 号进程。而 Network namespace 则让每个 pod 有了自己的网络。coT28资讯网——每日最新资讯28at.com

Pod 有自己的网络,node 节点也有自己的网络,那么流量是如何从 node 节点到 pod 的呢?coT28资讯网——每日最新资讯28at.com

HTTP 请求流转过程补充

coT28资讯网——每日最新资讯28at.com

每个 node 节点上都有:coT28资讯网——每日最新资讯28at.com

(1)kubelet:节点的小管家。coT28资讯网——每日最新资讯28at.com

(2)kube-proxy:操作节点的 iptables/ipvs 。coT28资讯网——每日最新资讯28at.com

(3)plugins:coT28资讯网——每日最新资讯28at.com

  • CRI:容器运行时接口
  • CNI:容器网络接口
  • CSI(可选):容器存储接口

每个 node 节点有自己的 root namespace,其中也包括网络相关的 root netns,每个 pod 有自己的 pod netns,从 node 到 pod 则可以通过 veth pairs 的方式连通,流量也正是通过此通道进行的流转。而构建 veth pairs、设置 pod network namespace、为 pod 分配 IP 地址等等工作则正是 CNI 的任务。coT28资讯网——每日最新资讯28at.com

至此,一个典型的 kubernetes 集群外部的 HTTP/HTTPS 请求如何达到 Pod 中的 container 的全过程就是这样了。coT28资讯网——每日最新资讯28at.com

参考资料:coT28资讯网——每日最新资讯28at.com

  • https://kubernetes.io/docs/concepts/services-networking/
  • https://learnk8s.io/kubernetes-network-packets

本文链接:http://www.28at.com/showinfo-26-54961-0.htmlKubernetes 外部 HTTP 请求到达 Pod 容器的全过程

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: 消息称阿里云削减政企定制项目和IoT硬件集成业务

下一篇: 我们一起聊聊枚举规范化

标签:
  • 热门焦点
  • 7月安卓手机性能榜:红魔8S Pro再夺榜首

    7月份的手机市场风平浪静,除了红魔和努比亚带来了两款搭载骁龙8Gen2领先版处理器的新机之外,别的也想不到有什么新品了,这也正常,通常6月7月都是手机厂商修整的时间,进入8月份之
  • 0糖0卡0脂 旭日森林仙草乌龙茶优惠:15瓶到手29元

    旭日森林无糖仙草乌龙茶510ml*15瓶平时要卖为79.9元,今日下单领取50元优惠券,到手价为29.9元。产品规格:0糖0卡0脂,添加草本仙草汁,清凉爽口,富含茶多酚,保留
  • SpringBoot中使用Cache提升接口性能详解

    环境:springboot2.3.12.RELEASE + JSR107 + Ehcache + JPASpring 框架从 3.1 开始,对 Spring 应用程序提供了透明式添加缓存的支持。和事务支持一样,抽象缓存允许一致地使用各
  • 一篇文章带你了解 CSS 属性选择器

    属性选择器对带有指定属性的 HTML 元素设置样式。可以为拥有指定属性的 HTML 元素设置样式,而不仅限于 class 和 id 属性。一、了解属性选择器CSS属性选择器提供了一种简单而
  • 共享单车的故事讲到哪了?

    来源丨海克财经与共享充电宝相差不多,共享单车已很久没有被国内热点新闻关照到了。除了一再涨价和用户直呼用不起了。近日多家媒体再发报道称,成都、天津、郑州等地多个共享单
  • 2天涨粉255万,又一赛道在抖音爆火

    来源:运营研究社作者 | 张知白编辑 | 杨佩汶设计 | 晏谈梦洁这个暑期,旅游赛道彻底火了:有的「地方」火了——贵州村超旅游收入 1 个月超过 12 亿;有的「博主」火了&m
  • 腾讯VS网易,最卷游戏暑期档,谁能笑到最后?

    作者:无锈钵来源:财经无忌7月16日晚,上海1862时尚艺术中心。伴随着幻象的精准命中,硕大的荧幕之上,比分被定格在了14:12,被寄予厚望的EDG战队以绝对的优势战胜了BLG战队,拿下了总决
  • 华为HarmonyOS 4.0将于8月4日发布 或搭载AI大模型技术

    华为宣布HarmonyOS4.0将于8月4日正式发布。此前,华为已经针对开发者公布了HarmonyOS4.0,以便于开发者提前进行适配,也因此被曝光出了一些新系统的特性
  • 三星折叠屏手机去年销售近1000万台 今年目标定为1500万

    7月29日消息,三星率先发力可折叠手机市场,在全球市场已经取得了非常亮眼的成绩,接下来会进一步巩固和扩大这一优势。三星在推出Galaxy Z Flip5和Galax
Top