安全

将单一应用程序分解为微服务可提供各种好处,包括更好的灵活性、可伸缩性以及服务复用的能力。但是,微服务也有特殊的安全需求:

  • 为了抵御中间人攻击,需要流量加密。
  • 为了提供灵活的服务访问控制,需要双向 TLS 和细粒度的访问策略。
  • 要审核谁在什么时候做了什么,需要审计工具。

Istio Security 尝试提供全面的安全解决方案来解决所有这些问题。

本页概述了如何使用 Istio 的安全功能来保护您的服务,无论您在何处运行它们。特别是 Istio 安全性可以缓解针对您的数据,端点,通信和平台的内部和外部威胁。

Istio 安全模型的组件构成。
Istio 安全概述

Istio 安全功能提供强大的身份,强大的策略,透明的 TLS 加密以及用于保护您的服务和数据的身份验证,授权和审计(AAA)工具。 Istio 安全的目标是:

  • 默认安全 : 应用程序代码和基础结构无需更改

  • 深度防御 : 与现有安全系统集成,提供多层防御

  • 零信任网络 : 在不受信任的网络上构建安全解决方案

访问我们的Mutual TLS Migration docs,开始在部署的服务中使用Istio安全功能。 请访问我们的安全任务,有关使用安全功能的详细说明。

如图所示,Istio 的 Citadel 用加载 Secret 卷的方式在 Kubernetes 容器中完成证书和密钥的分发。如果服务运行在虚拟机或物理机上,则会使用运行在本地的 Node agent,它负责在本地生成私钥和 CSR(证书签发申请),把 CSR 发送给 Citadel 进行签署,并把生成的证书和私钥分发给 Envoy。

高级架构

Istio 中的安全性涉及多个组件:

  • 堡垒 用于密钥和证书管理

  • Sidecar 和周边代理 实现客户端和服务器之间的安全通信

  • Pilot授权策略安全命名信息分发给代理

  • Mixer 管理授权和审计

Istio 安全架构
Istio 安全架构

在线面的部分中,我们将详细介绍 Istio 安全功能。

Istio 身份

身份是任何安全基础架构的基本概念。在服务到服务通信开始时,双方必须与其身份信息交换凭证以用于相互认证目的。 在客户端,根据安全命名信息检查服务器的标识,以查看它是否是该服务的授权运行程序。 在服务器端,服务器可以根据授权策略 确定客户端可以访问哪些信息,审核谁在什么时间访问了什么,根据服务向客户收费他们使用并拒绝任何未能支付账单的客户访问服务。

在 Istio 身份模型中,Istio 使用一流的服务标识来确定服务的身份。 这为表示人类用户,单个服务或一组服务提供了极大的灵活性和粒度。 在没有此类身份的平台上,Istio 可以使用可以对服务实例进行分组的其他身份,例如服务名称。

不同平台上的 Istio 服务标识:

  • Kubernetes: Kubernetes 服务帐户

  • GKE/GCE: 可以使用 GCP 服务帐户

  • GCP: GCP 服务帐户

  • AWS: AWS IAM 用户/角色 帐户

  • On-premises (non-Kubernetes): 用户帐户,自定义服务帐户,服务名称,istio 服务帐户或 GCP 服务帐户。

自定义服务帐户引用现有服务帐户,就像客户的身份目录管理的身份一样。

Istio 安全与 SPIFFE

SPIFFE 标准提供了一个框架规范,该框架能够跨异构环境引导和向服务发布身份。

Istio 和 SPIFFE 共享相同的身份文件:SVID (SPIFFE可验证身份证件)。 例如,在 Kubernetes 中,X.509 证书的 URI 字段格式为"spiffe://<domain>/ns/<namespace>/sa/<serviceaccount>”。 这使 Istio 服务能够建立和接受与其他 SPIFFE 兼容系统的连接。

Istio 安全性和 SPIRE,它是 SPIFFE 的实现,在 PKI 实现细节上有所不同。 Istio 提供更全面的安全解决方案,包括身份验证,授权和审计。

PKI

Istio PKI 建立在 Istio Citadel 之上,可为每个工作负载安全地提供强大的工作负载标识。 Istio 使用 X.509 证书来携带 SPIFFE 格式的身份。 PKI 还可以大规模自动化密钥和证书轮换。

Istio 支持在 Kubernetes pod 和本地计算机上运行的服务。 目前,我们为每个方案使用不同的证书密钥配置机制。

Kubernetes 方案

  1. Citadel 监视 Kubernetes apiserver,为每个现有和新的服务帐户创建 SPIFFE 证书和密钥对。 Citadel 将证书和密钥对存储为 Kubernetes secrets

  2. 创建 pod 时,Kubernetes 会根据其服务帐户通过Kubernetes secret volume将证书和密钥对安装到 pod。

  3. Citadel 监视每个证书的生命周期,并通过重写 Kubernetes 秘密自动轮换证书。

  4. Pilot 生成安全命名信息,该信息定义了哪些服务帐户可以运行某个服务。 Pilot 然后将安全命名信息传递给sidecar特使。

本地机器方案

  1. Citadel 创建 gRPC 服务以获取证书签名请求(CSR)。

  2. 节点代理生成私钥和 CSR,并将 CSR 及其凭据发送给 Citadel 进行签名。

  3. Citadel 验证 CSR 承载的凭证,并签署 CSR 以生成证书。

  4. 节点代理将从 Citadel 接收的证书和私钥发送给 Envoy。

  5. 上述 CSR 过程会定期重复进行证书和密钥轮换。

代理程序代理节点(开发中)

在不久的将来,Istio 将在 Kubernetes 中使用节点代理进行证书和密钥提供,如下图所示。请注意,本地计算机的标识提供流程是相同的,因此我们仅描述 Kubernetes 方案。

PKI 与 Kubernetes 中的节点代理
PKI 与 Kubernetes 中的节点代理

流程如下:

  1. Citadel 创建一个 gRPC 服务来接受 CSR 请求。

  2. 特使通过 Envoy 秘密发现服务(SDS)API 发送证书和密钥请求。

  3. 收到 SDS 请求后,节点代理会创建私钥和 CSR,并将 CSR 及其凭据发送给 Citadel 进行签名。

  4. Citadel 验证 CSR 中携带的凭证,并签署 CSR 以生成证书。

  5. 节点代理通过 Envoy SDS API 将从 Citadel 接收的证书和私钥发送给 Envoy。

  6. 上述 CSR 过程会定期重复进行证书和密钥轮换。

最佳实践

在本节中,我们提供了一些部署指南并讨论了一个真实的场景。

部署指南

如果有多个服务运维团队(又名SREs)在中型或大型集群中部署不同的服务,我们建议创建一个单独的Kubernetes名称空间让每个 SRE 团队隔离他们的访问权限。例如,您可以为 team1 创建 team1-ns 名称空间,为 team2 创建 team2-ns 名称空间,这样两个团队都无法访问彼此的服务。

Warning如果 Citadel 遭到入侵,则可能会暴露集群中的所有托管密钥和证书。我们强烈建议在专用命名空间中运行 Citadel(例如,istio-citadel-ns),以便仅限管理员访问群集。

示例

让我们考虑一个带有三种服务的三层应用程序:photo-frontendphoto-backenddatastore。照片 SRE 团队管理 photo-frontendphoto-backend 服务,而数据存储 SRE 团队管理 datastore 服务。 photo-frontend服务可以访问photo-backendphoto-backend 服务可以访问 datastore。但是,photo-frontend服务无法访问 datastore

在这种情况下,集群管理员创建三个名称空间:istio-citadel-nsphoto-nsdatastore-ns。管理员可以访问所有名称空间,每个团队只能访问自己的名称空间。照片SRE团队创建了两个服务帐户,分别在photo-ns命名空间中运行photo-frontendphoto-backend。数据存储区 SRE 团队创建一个服务帐户,以在datastore-ns命名空间中运行datastore服务。此外,我们需要在 Istio Mixer 中强制执行服务访问控制,使得photo-frontend无法访问数据存储区。

在此设置中,Kubernetes 可以隔离运营商管理服务的权限。 Istio 管理所有名称空间中的证书和密钥,并对服务实施不同的访问控制规则。

认证

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

  • 传输身份验证,也称为服务到服务身份验证:验证直接客户端进行连接。 Istio 提供 双向 TLS 作为传输身份验证的完整堆栈解决方案。 您可以轻松打开此功能,而无需更改服务代码。这个解决方案:

    • 为每个服务提供强大的身份,表示其角色,以实现跨群集和云的互操作性。
    • 保护服务到服务通信和最终用户到服务通信。
    • 提供密钥管理系统,以自动执行密钥和证书生成,分发和轮换。
  • 来源身份认证,也称为最终用户身份验证:验证原始客户端将请求作为最终用户或设备。 Istio 通过 JSON Web Token(JWT)验证和 Auth0Firebase AuthGoogle Auth 和自定义身份验证来简化开发人员体验,并且轻松实现请求级别的身份验证。

在这两种情况下,Istio 都通过自定义 Kubernetes API 将身份认证策略存储在Istio 配置存储中。 Pilot 会在适当的时候为每个代理保持最新状态以及密钥。此外,Istio 支持在许可模式下进行身份验证,以帮助您了解策略更改在其生效之前如何影响您的安全状态。

双向 TLS 认证

Istio 隧道通过客户端和服务器端进行服务到服务通信 Envoy 代理。对于客户端调用服务器,遵循的步骤是:

  1. Istio 将出站流量从客户端重新路由到客户端的本地 sidecar Envoy。

  2. 客户端 Envoy 与服务器端 Envoy 开始双向 TLS 握手。在握手期间,客户端 Envoy 还执行安全命名检查,以验证服务器证书中提供的服务帐户是否有权运行目标服务。

  3. 客户端 Envoy 和服务器端 Envoy 建立了一个双向的 TLS 连接,Istio 将流量从客户端 Envoy 转发到服务器端Envoy。

  4. 授权后,服务器端 Envoy 通过本地 TCP 连接将流量转发到服务器服务。

安全命名

安全命名信息包含来自服务器标识的 N到N 映射,这些映射在证书中编码到由发现服务或 DNS 引用的服务名称。从身份 A 到服务名称 B 的映射意味着"允许 A 并授权其运行服务 B “。 Pilot 观察Kubernetesapiserver,生成安全的命名信息,并将其安全地分发给 sidecar Envoys。以下示例说明了为什么安全命名在身份验证中至关重要。

假设运行服务 datastore 的合法服务器仅使用 infra-team 标识。恶意用户拥有 test-team 身份的证书和密钥。恶意用户打算模拟服务以检查从客户端发送的数据。恶意用户使用证书和 test-team 身份的密钥部署伪造服务器。假设恶意用户成功攻击了发现服务或 DNS,以将 datastore 服务名称映射到伪造服务器。

当客户端调用 datastore 服务时,它从服务器的证书中提取 test-team 标识,并检查是否允许 test-team 运行带有安全命名信息的 datastore。客户端检测到 test-team 不允许运行 datastore 服务,并且验证失败。

认证架构

您可以使用身份认证策略为在 Istio 网格中接收请求的服务指定身份验证要求。网格操作者使用 .yaml 文件来指定策略。部署后,策略将保存在 Istio 配置存储中。 Pilot,Istio 控制器,监视配置存储。在任何策略变更后,Pilot 会将新策略转换为适当的配置,告知 Envoy sidecar 代理如何执行所需的身份验证机制。 Pilot 可以获取公钥并将其附加到 JWT 验证配置。或者,Pilot 提供 Istio 系统管理的密钥和证书的路径,并将它们安装到应用程序窗格以进行双向 TLS。您可以在 PKI 部分中找到更多信息。 Istio 异步发送配置到目标端点。代理收到配置后,新的身份验证要求会立即生效。

发送请求的客户端服务负责遵循必要的身份验证机制。对于源身份验证(JWT),应用程序负责获取 JWT 凭据并将其附加到请求。对于双向 TLS,Istio 提供目标规则。运营商可以使用目标规则来指示客户端代理使用TLS与服务器端预期的证书进行初始连接。您可以在PKI和身份部分中找到有关双向 TLS 如何在 Istio 中工作的更多信息。

认证架构
认证架构

Istio 将两种类型的身份验证以及凭证中的其他声明(如果适用)输出到下一层:授权。此外,运维操作者可以指定将传输或原始身份验证中的哪个身份作为委托人使用。

认证策略

本节中提供了更多 Istio 认证策略方面的细节。正如认证架构中所说的,认证策略是对服务收到的请求生效的。要在双向 TLS 中指定客户端认证策略,需要在 DetinationRule 中设置 TLSSettingsTLS 设置参考文档中有更多这方面的信息。和其他的 Istio 配置一样,可以用 .yaml 文件的形式来编写认证策略,然后使用 istioctl 进行部署。

下面例子中的认证策略要求 reviews 服务必须使用双向 TLS:

apiVersion: "authentication.istio.io/v1alpha1"
kind: "Policy"
metadata:
  name: "reviews"
spec:
  targets:
  - name: reviews
    peers:
  - mtls: {}

策略存储范围

Istio 可以在名称空间范围或网络范围存储中存储身份认证策略:

  • kind 字段指定了网格范围策略,其值为 MeshPolicy,名称为 default。例如:

    apiVersion: "authentication.istio.io/v1alpha1"
    kind: "MeshPolicy"
    metadata:
      name: "default"
    spec:
      peers:
      - mtls: {}
  • kind 字段和指定的命名空间指定名称空间范围策略,其值为 Policy。如果未指定,则使用默认命名空间。例如,名称空间 ns1

    apiVersion: "authentication.istio.io/v1alpha1"
    kind: "Policy"
    metadata:
      name: "default"
      namespace: "ns1"
    spec:
      peers:
      - mtls: {}

命名空间范围存储中的策略只能影响同一命名空间中的服务。 mesh-scope 中的策略可以影响网格中的所有服务。为防止冲突和滥用,只能在网状范围存储中定义一个策略。该策略必须命名为default并且有一个空的targets:部分。您可以在我们的目标选择器部分中找到更多信息。

目标选择器

身份认证策略的目标指定策略适用的服务。以下示例显示了一个targets:部分,指定该策略适用于:

  • 任何端口上的product-page服务。
  • 端口9000上的评论服务。
targets:
 - name: product-page
 - name: reviews
   ports:
   - number: 9000

如果您未提供targets:部分,则 Istio 将策略与策略存储范围内的所有服务匹配。因此,targets:部分可以帮助您指定策略的范围:

  • 网格范围策略:在网格范围存储中定义的策略,没有目标选择器部分。网格中最多只能有一个网格范围的策略。

  • 命名空间范围的策略:在命名空间范围存储中定义的策略,名称为 default 且没有目标选择器部分。每个命名空间最多只能有一个名称空间范围的策略。

  • 特定于服务的策略:在命名空间范围存储中定义的策略,具有非空目标选择器部分。命名空间可以具有零个,一个或多个特定于服务的策略。

对于每项服务,Istio 都应用最窄的匹配策略。顺序是:特定于服务>名称空间范围>网格范围。如果多个特定于服务的策略与服务匹配,则 Istio 随机选择其中一个。运营商在配置其策略时必须避免此类冲突。

为了强制网状范围和命名空间范围的策略的唯一性,Istio 每个网格只接受一个身份认证策略,每个命名空间只接受一个身份认证策略。 Istio 还要求网格范围和命名空间范围的策略具有特定名称default

传输认证

peers:部分定义了策略中传输身份验证支持的身份验证方法和相关参数。该部分可以列出多个方法,并且只有一个方法必须满足认证才能通过。但是,从 Istio 0.7 版本开始,当前支持的唯一传输身份验证方法是双向 TLS。如果您不需要传输身份验证,请完全跳过此部分。

以下示例显示了使用双向 TLS 启用传输身份验证的peers:部分。

peers:
  - mtls: {}

目前,双向 TLS 设置不需要任何参数。因此,-mtls:{}- mtls:- mtls:null声明被视为相同。将来,双向 TLS 设置可以携带参数以提供不同的双向 TLS 实现。

来源身份认证

origins: 部分定义了原始身份验证支持的身份验证方法和相关参数。 Istio 仅支持 JWT 原始身份验证。但是,策略可以列出不同发行者的多个 JWT。与传输身份验证类似,只有一种列出的方法必须满足身份验证才能通过。

以下示例策略为原始身份验证指定了一个 origin: 部分,该部分接受 Google 发布的 JWT:

origins:
- jwt:
    issuer: "https://accounts.google.com"
    jwksUri: "https://www.googleapis.com/oauth2/v3/certs"

主认证绑定

主认证关系用键值对的方式存储绑定关系。默认情况下,Istio 使用 peers: 部分中配置的身份验证。如果在 peers: 部分中未配置身份验证,则 Istio 将保留身份验证。策略编写者可以使用 USE_ORIGIN 值覆盖此行为。此值将 Istio 配置为使用 origin 的身份验证作为主体身份验证。将来,我们将支持条件绑定,例如:当传输体为X时为 USE_PEER,否则为 USE_ORIGIN

以下示例显示了 principalBinding 键,其值为 USE_ORIGIN

principalBinding: USE_ORIGIN

更新认证策略

您可以随时更改身份认证策略,Istio 几乎实时地将更改推送到端点。但是,Istio 无法保证所有端点同时收到新策略。以下是在更新身份认证策略时避免中断的建议:

  • 启用或禁用双向 TLS:使用带有mode:键和PERMISSIVE值的临时策略。这会将接收服务配置为接受两种类型的流量:纯文本和 TLS。因此,不会丢弃任何请求。一旦所有客户端切换到预期协议,无论是否有双向 TLS,您都可以将 PERMISSIVE 策略替换为最终策略。有关更多信息,请访问Mutual TLS Migration tutorial
peers:
- mTLS:
    mode: PERMISSIVE
  • 对于 JWT 身份验证迁移:在更改策略之前,请求应包含新的 JWT。一旦服务器端完全切换到新策略,旧JWT(如果有的话)可以被删除。需要更改客户端应用程序才能使这些更改生效。

授权和鉴权

Istio 的授权功能 - 也称为基于角色的访问控制(RBAC) - 为 Istio Mesh 中的服务提供命名空间级别,服务级别和方法级别的访问控制。它的特点是:

  • 基于角色的语义,简单易用。
  • 服务到服务和最终用户对服务的授权
  • 通过自定义属性支持的灵活性,例如条件,角色和角色绑定。
  • 高性能,因为 Istio 授权是在 Envoy 本地强制执行的。

授权架构

Istio Authorization
Istio Authorization Architecture

上图显示了基本的 Istio 授权体系结构。运维人员使用.yaml文件指定 Istio 授权策略。部署后,Istio 将策略保存在Istio Config Store中。

Pilot 监督 Istio 授权策略的变更。如果发现任何更改,它将获取更新的授权策略。 Pilot 将 Istio 授权策略分发给与服务实例位于同一位置的 Envoy 代理。

每个 Envoy 代理都运行一个授权引擎,该引擎在运行时授权请求。当请求到达代理时,授权引擎根据当前授权策略评估请求上下文,并返回授权结果ALLOWDENY

启用授权

您可以使用 RbacConfig 对象启用 Istio Authorization。 RbacConfig对象是一个网格范围的单例,其固定名称值为default。您只能在网格中使用一个RbacConfig实例。与其他 Istio 配置对象一样,RbacConfig被定义为Kubernetes CustomResourceDefinition (CRD)对象。

RbacConfig对象中,运算符可以指定mode值,它可以是:

  • **OFF **:禁用 Istio 授权。
  • **ON **:为网格中的所有服务启用了 Istio 授权。
  • **ON_WITH_INCLUSION **:仅对包含字段中指定的服务和命名空间启用 Istio 授权。
  • **ON_WITH_EXCLUSION **:除了排除字段中指定的服务和命名空间外,网格中的所有服务都启用了 Istio 授权。

在以下示例中,为default命名空间启用了 Istio 授权。

apiVersion: "config.istio.io/v1alpha2"
kind: RbacConfig
metadata:
  name: default
  namespace: istio-system
spec:
  mode: ON_WITH_INCLUSION
  inclusion:
    namespaces: ["default"]

授权策略

要配置 Istio 授权策略,请指定ServiceRoleServiceRoleBinding。与其他 Istio 配置对象一样,它们被定义为Kubernetes CustomResourceDefinition (CRD)对象。

  • **ServiceRole **定义了一组访问服务的权限。
  • **ServiceRoleBinding **向特定主题授予 ServiceRole,例如用户,组或服务。

ServiceRoleServiceRoleBinding 的组合规定: 允许哪些条件做什么 。特别:

  • 指的是 ServiceRoleBinding 中的 subject 部分。
  • 做什么指的是 ServiceRole 中的 permissions 部分。
  • 哪些条件指的是你可以在 ServiceRoleServiceRoleBinding 中使用Istio属性指定的 conditions 部分。

ServiceRole

ServiceRole 规范包括规则,AKA 权限列表。每条规则都有以下标准字段:

  • services:服务名称列表。您可以将值设置为 * 以包括指定命名空间中的所有服务。

  • methods:HTTP 方法名称列表,对于 gRPC 请求的权限,HTTP 动词始终是 POST 。您可以将值设置为 * 以包含所有 HTTP 方法。

  • paths:HTTP 路径或 gRPC 方法。 gRPC 方法必须采用 /packageName.serviceName/methodName 的形式,并且区分大小写。

ServiceRole 规范仅适用于 metadata 部分中指定的命名空间。规则中需要 servicesmethods 字段。 paths 是可选的。如果未指定规则或将其设置为 *,则它适用于任何实例。

下面的示例显示了一个简单的角色:service-admin,它可以完全访问 default 命名空间中的所有服务。

apiVersion: "rbac.istio.io/v1alpha1"
kind: ServiceRole
metadata:
  name: service-admin
  namespace: default
spec:
  rules:
  - services: ["*"]
    methods: ["*"]

这是另一个角色:products-viewer,它有读取,GETHEAD,访问 default 命名空间中的products.default.svc.cluster.local 服务。

apiVersion: "rbac.istio.io/v1alpha1"
kind: ServiceRole
metadata:
  name: products-viewer
  namespace: default
spec:
  rules:
  - services: ["products.default.svc.cluster.local"]
    methods: ["GET", "HEAD"]

此外,我们支持规则中所有字段的前缀匹配和后缀匹配。例如,您可以在 default命名空间中定义具有以下权限的 tester 角色:

  • 完全访问前缀为 test-* 的所有服务,例如:test-bookstoretest-performancetest-api.default.svc.cluster.local
  • 阅读(GET)使用*/reviews后缀访问所有路径,例如:/books/reviews,/events/booksale/reviews/reviews in servicebookstore .default.svc.cluster.local
apiVersion: "rbac.istio.io/v1alpha1"
kind: ServiceRole
metadata:
  name: tester
  namespace: default
spec:
  rules:
  - services: ["test-*"]
    methods: ["*"]
  - services: ["bookstore.default.svc.cluster.local"]
    paths: ["*/reviews"]
    methods: ["GET"]

ServiceRole中,namespace +services +paths +methods的组合定义了如何访问服务。 在某些情况下,您可能需要为规则指定其他条件。例如,规则可能仅适用于服务的某个版本,或仅适用于具有特定标签的服务, 如 foo。您可以使用 constraints 轻松指定这些条件。

例如,下面的 ServiceRole 定义添加了一个约束,request.headers [version]v1v2扩展了以前的products-viewer角色。 约束支持的key值列在约束和属性页面中。在属性是map的情况下,例如request.headerskey是地图中的一个条目,例如request.headers [version]

apiVersion: "rbac.istio.io/v1alpha1"
kind: ServiceRole
metadata:
  name: products-viewer-version
  namespace: default
spec:
  rules:
  - services: ["products.default.svc.cluster.local"]
    methods: ["GET", "HEAD"]
    constraints:
    - key: request.headers[version]
      values: ["v1", "v2"]

ServiceRoleBinding

ServiceRoleBinding 规范包括两部分:

  • roleRef指的是同一命名空间中的 ServiceRole 资源。
  • subjects 分配给角色的列表。

您可以使用 user 或一组 properties 显式指定 subjectServiceRoleBinding subject 中的 property 类似于ServiceRole 规范中的 constraintproperty 还允许您使用条件指定分配给此角色的一组帐户。它包含一个 key及其允许的。约束支持的 key 值列在约束和属性页面中。

下面的例子显示了一个名为 test-binding-productsServiceRoleBinding,它将两个主题绑定到名为product-viewerServiceRole 并具有以下 subject

  • 代表服务的服务帐户 aservice-account-a
  • 代表 Ingress 服务的服务帐户istio-ingress-service-accountand,其中 JWT mail 声明为 `a@foo.com`。
apiVersion: "rbac.istio.io/v1alpha1"
kind: ServiceRoleBinding
metadata:
  name: test-binding-products
  namespace: default
spec:
  subjects:
  - user: "service-account-a"
  - user: "istio-ingress-service-account"
    properties:
      request.auth.claims[email]: "a@foo.com"
    roleRef:
    kind: ServiceRole
    name: "products-viewer"

如果您想要公开访问服务,可以将 subject 设置为user:"*" 。此值将 ServiceRole 分配给**所有(经过身份验证和未经身份验证的)**用户和服务,例如:

apiVersion: "rbac.istio.io/v1alpha1"
kind: ServiceRoleBinding
metadata:
  name: binding-products-allusers
  namespace: default
spec:
  subjects:
  - user: "*"
    roleRef:
    kind: ServiceRole
    name: "products-viewer"

要将ServiceRole分配给经过身份验证的用户和服务,请使用source.principal:"*"代替,例如:

apiVersion: "rbac.istio.io/v1alpha1"
kind: ServiceRoleBinding
metadata:
  name: binding-products-all-authenticated-users
  namespace: default
spec:
  subjects:
  - properties:
      source.principal: "*"
    roleRef:
    kind: ServiceRole
    name: "products-viewer"

使用其他授权机制

虽然我们强烈建议使用 Istio 授权机制,但 Istio 足够灵活,允许您通过 Mixer 组件插入自己的身份验证和授权机制。 要在 Mixer 中使用和配置插件,请访问我们的策略和遥测适配器文档

See also

展示如何在服务网格中进行基于角色的访问控制。

如何渐进式的为现有 Istio 服务添加双向 TLS 支持。

介绍如何使用 Istio 认证策略设置双向 TLS 和基本的终端用户认证。

如何在 Kubernetes 中启用 Citadel 的健康检查。

展示如何对 Istio service 进行健康检查。

运维人员如何使用现有根证书配置 Citadel 进行证书以及密钥的签发。