Fault Injection

故障注入 #

故障注入是一种系统测试方法,它涉及将网络故障和错误故意引入系统。它可以用来测试设计或配置的缺陷,并确保系统能够处理故障并从错误中恢复。

通过solarmesh,可以方便的在页面注入故障,以测试服务的容错性。您可以配置任意HTTP故障码,并将其注入到由solarmesh接管的目标服务中。在配置生效后,您对目标服务的HTTP请求将会返回设置好的故障码。

试试看 #

假设我们已经部署过bookinfo示例项目(见 快速开始/安装/使用solarctl安装示例项目),并且为bookinfo示例项目的服务接入了sidecar(见 快速开始/接管服务)

访问我们事先部署好的示例项目bookinfo的页面,多刷新几次,您会发现在没有任何策略干预的情况下,页面中 Book Reviews 一栏呈现三种状态: 红星、黑星和无星,它们的出现概率约为1:1:1。

bookinfo-productpage

此时进入SolarMesh的流量视图界面,您可以看到这样的一幅流量拓扑图。

流量视图

此时可以发现,reviews 服务有3个版本对应着3种状态,我们先在 DestinationRule 上配置 reviews 的版本。

dr版本号

然后在 VirtualService 创建一份http策略,配置故障注入,我们将故障码 500 注入到 reviews 服务上。

故障注入

再次访问示例项目bookinfo的页面。我们可以发现故障已经产生,reviews 服务已经开始报错了。

bookinfo-故障注入

此时进入SolarMesh的流量视图界面,您可以看到这样的一幅流量拓扑图。由于请求已经被系统强制返回500错误,并不会抵达真正的服务,所以可以看到是 productpage 访问了reviews.demo.svc.cluster.local 这个host,并且流量线是红色的。

流量视图-故障注入