详解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 模式),行为可能略有差异;提供更多细节可进一步确认!

相关推荐
2301_787328496 小时前
24.集群及高可用-Keepalived
linux·运维·云原生
张忠琳6 小时前
volcano scheduler v1.3.0源码分析之启动流程
云原生·kubernetes·volcano
東雪蓮☆8 小时前
K8S 概念、安装与核心工作机制详解
linux·运维·云原生·容器·kubernetes
张忠琳9 小时前
【kubernetes/k8s源码分析】kube-controller-manager之node controller源码分析
云原生·容器·kubernetes
bxlj_jcj9 小时前
K8S原理刨析
云原生·容器·kubernetes
三坛海会大神55511 小时前
K8S入门1.20版本部署
云原生·容器·kubernetes
小诸葛的博客12 小时前
istio 为什么在主机上抓不到15001和15006的流量
云原生·istio
FJW02081414 小时前
容器编排大王Kubernetes——介绍与部署(1)
云原生·容器·kubernetes
-L71 天前
【Kubernetes】常见面试题汇总(十九)
云原生·容器·kubernetes