服务治理技术选型

Istio 是一个开源的**服务网格(Service Mesh)**平台,主要用来管理微服务之间的通信。

可以把它理解成:

👉 在系统里"所有服务之间通信的中间层管家"。

如果说 Kubernetes 负责"部署和调度服务",

那 Istio 负责"服务之间怎么通信、怎么控制、怎么监控"。

在微服务架构里,会有很多复杂问题:

  • 服务之间怎么调用?(A 调 B)
  • 调用失败怎么办?重试?熔断?
  • 怎么做灰度发布 / 金丝雀发布?
  • 怎么统计调用延迟、成功率?
  • 怎么保证通信安全(加密、认证)?

👉 这些问题如果写在业务代码里,会非常乱。

Istio 的作用就是:
把这些"通用通信能力"从业务代码里抽出来统一处理。

Istio 通过一个很关键的设计:

Sidecar(边车模式)

每个服务旁边都会多一个代理(通常是 Envoy):

复制代码
服务A  ↔  Sidecar代理A  ↔  Sidecar代理B  ↔  服务B

👉 所有流量都会经过代理,而不是服务直接通信。

这样带来的好处:

  • 不改业务代码就能控制流量
  • 可以统一做限流、重试、日志
  • 可以插入安全策略(mTLS)

它能做

1️⃣ 流量管理

  • 灰度发布(10%流量到新版本)
  • A/B测试
  • 路由控制

2️⃣ 可观测性

  • 请求成功率
  • 延迟
  • 调用链追踪(Tracing)

3️⃣ 安全

  • 服务间自动加密(mTLS)
  • 身份认证
  • 权限控制

4️⃣ 容错能力

  • 超时
  • 重试
  • 熔断

和 Kubernetes 的关系

  • Kubernetes:负责部署、扩缩容
  • Istio:负责服务通信治理

👉 两者是互补关系,不是替代关系。

相关推荐
500842 小时前
昇腾 CANN 的五层架构,到底分了哪五层
java·人工智能·分布式·架构·ocr·wpf
摇滚侠2 小时前
Java 零基础全套教程,File 类与 IO 流,笔记 177-178
java·开发语言·笔记
雨落在了我的手上2 小时前
初始java(十):类和对象(⼆)
java·开发语言
莫雪歌3 小时前
Java AI 应用开发实践:基于 Spring Boot 实现 Chat、Memory、RAG 与 Tool Calling
java·aigc
SmartBrain4 小时前
AI全栈开发(SDD):慢病管理系统工程级设计
java·大数据·开发语言·人工智能·架构·aigc
梦想CAD控件4 小时前
网页端对DWG图纸进行预览与批注(CAD轻量化)
java·前端·javascript
老毛肚4 小时前
Spring boot 特性和自写Reids组件
java·spring boot·后端
极光代码工作室4 小时前
基于SpringBoot的课程管理系统
java·springboot·web开发·后端开发
JustNow_Man4 小时前
【opencode】安装使用daytona沙箱插件
android·java·javascript
武子康5 小时前
Java-05 深入浅出 MyBatis动态SQL与参数拼接完全指南
java·spring boot·后端