Ingress出现诡异的HTTP状态码“000”

背景

        近日,有朋友提到他们的ingress出现了“000”状态码,我一开始是不信的,认为他们可能是打印日志的姿势不对,因为http状态码压根就没有000的说法,于是要求对方上图,没想到,还真有。。。是怎么回事呢?让我们继续往下看。

问题现象

        这是发生在比较低的版本0.25.1的身上,我们先看下定义的日志格式,status引用的是内置变量,没问题。

接着我们看看这诡异的“000”状态码截图,真的出现了

擦一擦眼睛,我们看下正常的请求,记录的状态码是200,很肯定状态码的位置是正确的

有图有真相,不信都不行,现在整个人都不好了,这到底怎么回事呢?

找寻真相

翻了一下源码,有这样一个逻辑,当捕获不到有效状态码时,会返回0,原来如此。

结语

        综上所述,HTTP状态码没有“000”的认知并没有被颠覆,它只是ingress在获取不到具体状态码时的返回值,一般出现这种情况,很可能是通信期间网络出现了问题,需要根据具体情况进行排查,本期分享就到这里,谢谢!

 欢迎订阅我的公众号「SRE运维手记」,可扫下方二维码,或者微信搜“SRE运维手记”

e45dc07b6fd04114a9f5fe6f4772a886.jpeg

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值