我们已经将一个服务部署到Kubernetes (EKS),其中包含一个NLB服务和两个在其后面运行的pods。当我从本地机器运行负载测试(简单的GET请求)时,所有请求都转到一个pod,而另一个则处于空闲状态。
当我使用3个不同的客户端(Safari,FF和curl)手动测试时,请求似乎找到了到达这两个pod的方法。所以问题似乎出在负载测试客户端上。
当我运行负载测试时,为什么请求有粘性行为?这是可以解决的问题吗?这样我的负载测试的请求就可以分布在pod上了吗?这会影响我的测试结果,因为pod最终会向外扩展,但请求只能继续由单个pod提供服务。
我使用的工具是k6.io。我试过设置a configuration to disable connection re-use,但也没有用。
发布于 2021-01-13 18:37:35
这似乎是我正在使用的负载测试工具的一个问题,并且与这个问题-- https://github.com/loadimpact/k6/issues/1752 --有一定的关系。
我调整了我正在使用的k6 Docker镜像的版本,它正确地选择了noConnectionReuse选项。
https://stackoverflow.com/questions/65699652
复制相似问题