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 全套治理能力

相关推荐
运维栈记3 小时前
如何排错运行在Kubernetes集群中的服务?
云原生·容器·kubernetes
古城小栈5 小时前
微服务网格:Istio 流量管理实战
微服务·架构·istio
木风小助理11 小时前
Kubernetes持久化存储架构深度解析:从易失的Pod到永恒的数据
kubernetes
一周困⁸天.11 小时前
K8s -蓝绿发布与金丝雀发布
docker·容器·kubernetes
永不停歇的蜗牛11 小时前
K8S之rke2证书过期,如何处理以及遇到的问题
服务器·容器·kubernetes
你想考研啊13 小时前
k8s使用kubectl报错
java·docker·kubernetes
回忆是昨天里的海14 小时前
记录线上k8s拉取不了阿里云镜像的一次临时处理
阿里云·容器·kubernetes
木风小助理14 小时前
Kubernetes Service 架构深度解析:从虚拟IP到流量的智能寻址
kubernetes
运维行者_14 小时前
APM 性能监控是什么?从应用监控与网站监控了解基础概念
网络·数据库·云原生·容器·kubernetes·智能路由器·运维开发
小毅&Nora14 小时前
【云计算】【Kubernetes】 ⑥ K8S Pod优雅下线全解析:从preStop到Eureka下线实战
kubernetes·云计算·优雅下线