详解istio mtls双向身份认证

Istio 中网格内 Pod 间通信流量的默认加密状态

在 Istio 服务网格中,如果两个 Pod 都已注入 Sidecar 代理(即都在网格内),它们之间的通信流量默认会加密。这是通过互信 TLS(mTLS,Mutual TLS)实现的,Istio 会自动将网格内部流量升级为 mTLS,确保服务间加密传输和身份验证。

详细说明

  • 默认配置(PERMISSIVE 模式) :Istio 的默认 PeerAuthentication 策略是 PERMISSIVE 模式,这允许 Sidecar 同时接受明文(plaintext)和 mTLS 流量。 然而,Istio 的 Envoy 代理会智能检测:当源和目标 Pod 都有代理时,它会自动优先使用 mTLS 发送加密流量,而非明文。
  • 自动升级机制:流量在两个代理(Proxy Enforcement Points, PEPs)之间会自动升级为 mTLS,无需手动干预。这确保了网格内服务的安全通信。
  • 严格模式(STRICT):如果需要强制仅允许 mTLS(拒绝明文),可以通过配置 PeerAuthentication 切换到 STRICT 模式。

示例配置(可选,切换到 STRICT)

yaml 复制代码
apiVersion: security.istio.io/v1beta1
kind: PeerAuthentication
metadata:
  name: default
spec:
  mtls:
    mode: STRICT

注意事项

  • 适用范围:仅限于网格内(mesh-internal)流量;外部流量需额外配置 Gateway 或 DestinationRule。
  • 验证方法 :使用 istioctl authn tls-check 命令检查 Pod 间的 mTLS 状态,或通过 Kiali 仪表盘可视化流量。

如果你的 Istio 版本或环境有自定义配置(如 Ambient 模式),行为可能略有差异;提供更多细节可进一步确认!

相关推荐
阿里云云原生10 分钟前
Android App 崩溃排查实战:如何利用 RUM 完整数据与符号化技术定位问题?
android·阿里云·云原生·rum
熊出没2 小时前
Kubernetes 实操命令大全
云原生·容器·kubernetes
阿里云云原生2 小时前
深度解析云监控 2.0 日志审计:统一采集、实体建模与告警溯源能力
阿里云·云原生·云监控·可观测
阿基米东6 小时前
Let‘s Encrypt 是什么?它是如何工作的?
云原生·https·云计算
故事写到这6 小时前
第一章 Ubuntu24.04环境下的K8S部署【入门保姆级】
云原生·容器·kubernetes
探索云原生6 小时前
Buildah 简明教程:让镜像构建更轻量,告别 Docker 依赖
linux·docker·云原生·go·cicd
走路带_风6 小时前
Ubuntu server 22.04 安装kubernetes
云原生·容器·kubernetes
Xyz996_8 小时前
K8S-Configmap资源
云原生·容器·kubernetes
Warren988 小时前
datagrip新建oracle连接教程
数据库·windows·云原生·oracle·容器·kubernetes·django
ascarl20109 小时前
准确--Kubernetes 修改 NodePort 端口范围操作文档
云原生·容器·kubernetes