helm安装istio_深度解析Istio系列之安全模块篇

单体应用拆分为微服务之后,提高了开发效率,增加系统系统稳定性,提高运维效率等等一系列的好处,但随之也带来了安全方面的风险,之前都是本地调用,现在都改为走网络协议调用接口,今天着重介绍的是微服务架构中的新贵Istio中安全模块分析,Istio安全的三大目标:

  • 默认安全(Security by default):应用程序代码和基础结构无需更改。
  • 深度防御(Defense in depth):与现有安全系统集成,提供多层防御。
  • 零信任网络(Zero-trust network):在不受信的网络上,构建安全解决方案。

架构

520052c2ad5324d1afb4e1b332b6d65d.png

如上图,Istio安全涉及到组件有:

  • Citadel 用于密钥和证书的管理。
  • Proxy 实现客户端与服务器端安全通信。
  • Pilot 将授权策略和安全命名信息分发给代理。
  • Mixer:校验授权和审计。

Istio 身份

身份信息

身份信息是安全基础架构的基本概念,在服务和服务的通信开始前,双方必须用其身份信息交换凭证,以达到相互认证的目的,根据安全信息达到鉴权的目的,同时根据身份信息可以进行审计,在kubernetes的环境下Istio身份标识使用Service Account。

PKI

PKI(Public Key Infrastructure)建立在Istio citadel 之上,Istio 使用 X.509 证书来携带 SPIFFE 格式的身份信息,PKI 还可以大规模自动化地进行密钥和证书轮换。

证书生成流程

基于kubernetes环境下证书生成流程如下:

cbd2bc893b32724d0713c45e50dc8e2e.png

citadel同时也会监听每个证书的生命周期,通过重写 Kubernetes secret 自动轮换证书。Pilot生成安全信息即授权信息,Pilot将授权信息分发给envoy每个命名空间下有个default serviceaccount,citadel会为它创建一个名为istio.default的secret。

[root@kube01 ~]$ kubectl -n foo get secrets

NAME TYPE DATA AGE

default-token-bdpmg kubernetes.io/service-account-token 3 8d

istio.default istio.io/key-and-cert 3 8d

默认在该命名空间下新建的istio应用都使用该secret。

istio-certs:

Type: Secret (a volume populated by a Secret)

SecretName: istio.default

Optional: true

当为deployment指定了非默认serviceaccount,则秘钥也将使用新的secret。

istio-certs:

Type: Secret (a volume populated by a Secret)

SecretName: istio.bookinfo-productpage

Optional: true

认证

Istio提供两种类型的身份验证:

  • 传输身份验证,也称为服务到服务身份验证:验证直接客户端进行连接。Istio提供相互TLS 作为传输身份验证的完整堆栈解决方案。
  • 源身份验证,也称为最终用户身份验证:验证将请求作为最终用户或设备的原始客户端。

具体信息参见官网,本文章主要介绍第一种。

相互 TLS身份验证(mTLS)

mTLS本身流程如下图所示:

e8469d05e62eda0f9d890d01f1f7f1e5.png

在Istio握手期间,客户端envoy还进行安全命名检查,验证服务器证书中提供的服务账户是否有权限运行目标服务。

认证架构

通过yaml文件配置身份认证策略,部署后策略保存在Istio配置存储中,Pilot监听配置存储,当发生变化后Pilot将策略转变为适当的配置(envoy识别的配置等),再通知envoy如何执行身份认证机制,Pilot提供Istio系统管理的密钥和证书的路径,并将它们安装到应用程序mesh以进行相互TLS。Istio通过异步发送配置到目标端点,代理收到消息后,新的身份认证立即生效。

认证架构如下图所示:

5e2fba3f4e281dd1f09ba82a2a4dc024.png

部署影响

在部署Istio平台时,通过yaml则是istio-demo-auth.yaml,该yaml安装为所有控制面板中envoy添加了tls相关信息,在helm中则是global.controlPlaneSecuretyEnable: true,开启后实质是为controlPlaneAuthPolicy: MUTUAL_TLS,分析添加该属性后发生的变化如下:

控制面板

Istio-policy,istio-telemetry,istio-pilot,三个组件在istio-proxy中envoy进程启动时会指定配置文件,依次为envoy_policy.yaml,envoy_telemetry.yaml,envoy_pilot.yaml,在这些文件中相同都增加如下:

"tls_context": {

"common_tls_context": {

"alpn_protocols": "h2

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值