k8s:服务网格Service Mesh(服务网格)istio和envoy

微服务-》k8s-》服务网格

这是技术进化方向

Service Mesh 为什么重要?

因为它把微服务最困难的部分 ------ 服务治理 ------ 从业务代码中移除,放到基础设施层。

  1. 以前要写复杂 SDK

    → 现在全自动由 Envoy 完成

  2. 以前安全靠自己管理证书

    → 现在 Istio 自动给每个服务下发证书

  3. 以前灰度发布要写代码、改配置

    → 现在改一个 YAML 即可

Service Mesh(服务网格)就是一个用来管理微服务之间通信的基础设施层

它 不需要改业务代码,通过 Sidecar 代理(如 Envoy) 自动提供:

  • 流量管理(路由、灰度、负载均衡)
  • 安全(mTLS、认证、鉴权)
  • 可观测性(指标、日志、链路追踪)
  • 故障恢复(重试、熔断、超时)

不用 SDK、无需修改业务逻辑,应用只写业务代码。

服务网格就是替代了原先java引入的一些依赖

👉 服务网格不是取代微服务,而是取代微服务中的"服务治理部分"。

👉 让你不再把大量非业务代码写在微服务里。

所有请求都经过 Envoy,不直接经过业务代码。

Envoy 做:

流量转发、路由、负载均衡

超时、重试、限流、熔断

mTLS 加密、证书管理

指标、日志、链路追踪

控制面(Istio)做:

把策略下发给 Envoy

管理证书

管理流量规则

监控 sidecar 状态

Service Mesh = 控制面 + 数据面

✔ 数据面(Data Plane)→ Envoy

负责真正处理流量。

✔ 控制面(Control Plane)→ Istio

负责策略、配置、证书、安全、服务发现。

完整结构:

复制代码
      +------------------+
      |   Istio (控制面)   |
      +------------------+
        ↓      ↓      ↓
   Envoy   Envoy   Envoy
   Sidecar Sidecar Sidecar
        ↓      ↓      ↓
     App     App     App

kube-proxy = 基本的流量转发器

Envoy = 智能流量控制器

两者的关系是什么?

默认情况下,两者都存在:

请求 → kube-proxy (iptables) → Pod 内部 → Envoy sidecar → 应用

但在 Istio 中:

Envoy 可以取代 kube-proxy 的部分工作

具体取代的是:

Service 的负载均衡(通过 EDS/Cluster 代替)

Service 之间的流量路由(Envoy instead of kube-proxy)

所以:

在 Istio 中,kube-proxy 的作用弱化,但仍然需要存在。

(也可以彻底禁用 kube-proxy,但那属于高级玩法)

理解重点:kube-proxy 是底层网络,Envoy 是高层治理

你可以这样理解:

kube-proxy = "Linux iptables 提供的基础网络连通能力"

Envoy = "Nginx + API 网关 + 安全代理 + 流量治理 + 可观测性"

Nginx Ingress Controller = 传统入口控制器(不属于 Service Mesh)

Istio Gateway = Service Mesh 的入口 Envoy,具备 Mesh 全套治理能力

相关推荐
稚辉君.MCA_P8_Java19 小时前
Gemini永久会员 containerd部署java项目 kubernetes集群
后端·spring cloud·云原生·容器·kubernetes
U***e6320 小时前
DevOps在云原生中的Service Mesh
云原生·devops·service_mesh
间彧21 小时前
Helm深度解析:Kubernetes应用管理的利器
kubernetes
间彧21 小时前
K8s: 如何通过kubectl命令实时监控滚动更新的详细过程?
kubernetes
岚天start1 天前
K8S环境中Containerd运行时占用文件定位清理
java·rpc·kubernetes
赵文宇(温玉)1 天前
不翻墙,基于Rancher极速启动Kubernetes,配置SSO登录,在线环境开放学习体验
学习·kubernetes·rancher
炸裂狸花猫1 天前
开源域名证书工具 - cert-manager
云原生·容器·kubernetes·开源·cert-manager
会飞的小蛮猪1 天前
Ubuntu24.04基于Docker部署K8s(使用私服部署)
经验分享·docker·云原生·容器·kubernetes