kubernetes - 在 kubernetes 中自动缩放期间某些请求失败
问题描述
我在 microk8s 上建立了一个 k8s 集群,并将我的应用程序移植到它上面。我还添加了一个水平自动缩放器,它根据 cpu 负载添加 pod。自动缩放器工作正常,当负载超出目标时它会添加 pod,并且当我在一段时间后移除负载时,它会杀死 pod。
问题是我在完全相同的时刻注意到自动缩放器正在创建新的 Pod,一些请求失败:
POST Response Code : 200
POST Response Code : 200
POST Response Code : 200
POST Response Code : 200
POST Response Code : 200
POST Response Code : 502
java.io.IOException: Server returned HTTP response code: 502 for URL: http://10.203.101.61/gateway/compile
POST Response Code : 502
java.io.IOException: Server returned HTTP response code: 502 for URL: http://10.203.101.61/gateway/compile
POST Response Code : 200
POST Response Code : 502
java.io.IOException: Server returned HTTP response code: 502 for URL: http://10.203.101.61/gateway/compile
POST Response Code : 502
java.io.IOException: Server returned HTTP response code: 502 for URL: http://10.203.101.61/gateway/compile
POST Response Code : 200
POST Response Code : 200
POST Response Code : 200
POST Response Code : 200
POST Response Code : 200
POST Response Code : 200
POST Response Code : 200
POST Response Code : 200
我想知道这是什么原因以及如何解决?
更新:我认为最好向您提供有关我的设置的更多信息:
流量来自集群外部,但 k8s 节点和生成请求的程序都在一台机器上,因此不存在网络问题。有一个自定义的 nginx 组件不做负载平衡,只是充当反向代理并将流量发送到相应的服务。
我进行了另一个测试,它给了我更多信息。我运行了相同的基准测试,但这次我没有将请求发送到反向代理 (nginx),而是使用了该特定服务的 IP 地址,并且在自动缩放器完成其工作并启动多个 pod 时我没有失败的请求。我不确定问题是 Nginx 还是 k8s?
解决方案
推荐阅读
- java - Maven 阴影插件替换 persistence.xml
- javascript - 单击模态同意按钮时未选中复选框
- php - 如何检查字符串是否不存在然后返回 false?
- apache-kafka - 如何使用 kafka-python 获取 kafka 主题的分区?
- c - 当我尝试使用 struct 运行程序时出现分段错误(核心转储)
- c# - C# Compile OutOfMemory 错误,而我正在尝试动态生成要编译的文件操作代码
- clojure - Clojure - 使用 Cloud Firestore 获取实时更新
- python - 在字符串列表中搜索的高效且最快的方法
- c# - 将多个流序列化为一个流
- graphql - Apollo GraphQL 中的模式拼接不解析来自其他部分的类型