假设有 ABCD 四个节点,D 节点为后端 api ,BC 是两个 apisix 网关通过 docker 部署并配置了 D 节点为上游服务,A 节点是个 nginx 将流量负载到 BC 上,目前请求 api 总是会间歇性出现 499 问题,查看 access.log 发现只在 C 节点出现这类报错,B 节点流量完全正常。并且在 C 节点同一个接口有时正常,有时就 499 。C 节点 499 报错的请求压根就没到 D 节点上,D 节点的日志里面没有 C 节点调用的记录。大佬们给点思路,排查了一天了,还没找到原因。
1
yannxia 230 天前
Nginx 499 不是因为客户端断链导致的么,主要检查下 Client -> A -> C 这个链路,为什么 A -> C 超时?把 C 的日志级别调低点先。不过看起来你自己绕过 A 直接对 C 进行一些持续请求应该也能复现的话,那就比较容易定位了。
|