背景
近日,有朋友提到他们的ingress出现了“000”状态码,我一开始是不信的,认为他们可能是打印日志的姿势不对,因为http状态码压根就没有000的说法,于是要求对方上图,没想到,还真有。。。是怎么回事呢?让我们继续往下看。
问题现象
这是发生在比较低的版本0.25.1的身上,我们先看下定义的日志格式,status引用的是内置变量,没问题
接着我们看看这诡异的“000”状态码截图,真的出现了
擦一擦眼睛,我们看下正常的请求,记录的状态码是200,很肯定状态码的位置是正确的
有图有真相,不信都不行,现在整个人都不好了,这到底怎么回事呢?
找寻真相
翻了一下源码,有这样一个逻辑,当捕获不到有效状态码时,会返回0,原来如此。
结语
综上所述,HTTP状态码没有“000”的认知并没有被颠覆,它只是ingress在获取不到具体状态码时的返回值,一般出现这种情况,很可能是通信期间网络出现了问题,需要根据具体情况进行排查,本期分享就到这里,谢谢!