Istio 中的安全管控出口流量,第二部分

使用 Istio 的出口流量管控来阻止相关出口流量攻击。

Jul 10, 2019 | By Vadim Eisenberg - IBM

欢迎来看 Istio 对出口流量进行安全管控系列文章的第 2 部分。 在这个系列文章的第一部分, 我提出了出口流量相关攻击和针对出口流量进行安全管控我们收集的要求点。 在这一期中,我会讲述对出口流量进行安全管控的 Istio 方式,并且展示 Istio 如何帮你阻止攻击。

Istio 中的出口流量安全管控

为了在 Istio 中实施出口流量的安全管控,你必须通过出口网关将 TLS 流量发送到外部服务。 或者可以通过出口网关发送 HTTP 流量,并且让出口网关来发起执行 TLS

两种选择各有利弊,你应该根据你的具体场景进行选择。选择的关键取决于你的应用程序是否能发送不加密的 HTTP 请求和你团队的安全策略是否允许发送不加密的 HTTP 请求。 例如,如果你的应用程序使用了某些客户端库,用这些库来对流量进行加密,但是它无法取消加密,你就不能使用发送不加密 HTTP 流量的选项。万一你团队的安全策略无法让你在 pod 内发送不加密的 HTTP 请求也是一样的(pod 外的流量由 Istio 来加密)。

如果应用程序发送 HTTP 请求,并且由出口网关发起执行 TLS,你就可以监控 HTTP 信息,像 HTTP 方法、HTTP 头和 URL 路径。也可以根据上面说的 HTTP 信息来定义策略。如果是由应用程序发起执行 TLS,你就可以对源 pod 的 TLS 流量的 SNI 和服务账号进行监控,并且基于 SNI 和服务账号定义策略。

您必须确保你集群到外部的流量不能绕过出口网关。Istio 不能给您确保这一点, 所以您必须使用一些附加的安全机制, 比如 Kubernetes 网络策略 或者 L3 防火墙。 看一个 Kubernetes 网络策略配置 的例子。 根据 纵深防御 的概念,为同一个目标使用的安全机制越多越安全。

您也必需也要确保 Istio 控制平面和出口网关不能被破坏。您的集群里面可能有成百上千的应用程序 Pod,而只有十几个 Istio 控制平面 Pod 和网关。 您可以也应该聚焦在保护控制平面 Pod 和网关,因为这比较容易(需要保护的 Pod 数量很少),并且这对集群的安全性是最关键的。 如果攻击者破坏了控制平面和出口网关,他们可以违反任何策略。

根据环境的不同,你可能有多种工具来保护控制平面 pod。合理的安全策略如下:

一旦你通过出口网关引导了出口流量,并且应用了附加的安全机制,就可以进行安全的监控和施加对流量的安全策略。

下图展示了 Istio 的安全架构,用 L3 防火墙进行了加强,L3 防火墙就是附加安全机制的一部分,它应该在 Istio 的外面。

带有出口网关和 L3 防火钱的 Istio 安全架构
带有出口网关和 L3 防火钱的 Istio 安全架构

可以简单的配置 L3 防火墙,使它只允许通过 Istio 入口网关来的流量,并且只允许通过 Istio 出口网关出去的流量。网关的 Istio 代理执行策略,并且和在网格中其它所有代理一样上报检测信息。

现在我们来测试一下可能的攻击,并且我会给你们展示 Istio 中的出口流量安全管控是怎么阻止攻击的。

阻止可能的攻击

参考以下出口流量的安全策略:

假设攻击者有以下目标:

现在假设攻击者设法在攻破应用程序 A 的其中一个 pod,并且试图使用这个被攻破的 pod 来执行被禁止的访问。攻击者可能试试运气直接访问外部服务。你会对这个直接的尝试做出如下反应:

直接攻击失败的话,恶意攻击者可能会使用高级攻击方式:

据我们所见,所有禁止的访问都可以阻止,或者至少可以监控到,在以后可以被阻止。 如果看到当前设计中涉及出口流量或安全漏洞的其它攻击,我们将很高兴听到它

总结

希望我能说服您:Istio 在阻止相关出口流量攻击上是一个非常高效的工具。在这个系列文章的下一部分,我对 Istio 出口流量安全管控方案和其它的方案进行了对比,比如 Kubernetes 网络策略和已有的出口代理/防火墙。