java.io.EOFException: Unexpected EOF read on the socket

项目:vue-element-admin

最近在写一个私人项目,在发送post请求时,遇到了这个坑爹的EOFException,花了差不多一个周末的时间才解决(其实是因为自己菜,不明白http相关原理),特此记录下,以备后续排查错误。

EOFException 的含义

Signals that an end of file or end of stream has been reached unexpectedly during input.
在输入过程中意外地到达文件结尾或流结束的信号

错误排查

springboot应用打印出debug级别日志(在排查问题时,可以尝试使用debug级别日志)发现:通过postman发送的请求,能够看到request请求的请求体;但通过前端应用发送的请求,没有request请求体。

而request请求体是流式数据,如果在其他地方消费过,不做特殊处理的话,后面的应用就消费不到了!

再返回前端应用进行查看。

 

image.png

 

前端通过node转发到后端应用,思考了半天,觉得只有mock才会影响到request请求体,所以去mock-server.js中去查看。

 

注意:注销后需要重启项目


果然,在mock中消费了requestBody,导致在node转发时,request请求体丢失。

EOFException根因分析

前端mock把requestBody给消费掉了,导致传到后端没有body,后端在解析的时候发现request请求头的content-length是59,就一直等待接收数据,与此同时,前端也在等待后端返回结果。1分钟后,前端等待超时,前端发EOF请求(具体为何会发EOF还需要进一步学习),后端收到以后,发现和预期的消息不一致,就报了EOF这个错误。

 

  • 4
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
这个异常通常出现在使用Spring框架进行HTTP消息转换时,表示在读取输入消息时发生了I/O错误。其中,嵌套异常`ClientAbortException`表示客户端中止了连接,而`EOFException`表示在套接字上读取时发生了意外的EOF(文件结束)。 通常情况下,这个异常可能是由以下几种原因引起的: 1. 客户端中止连接:客户端在请求处理期间中止了连接,这可能是由于网络故障、超时或其他原因导致的。这种情况下,异常是预料之内的,可以忽略。 2. 请求过大:如果请求体过大,超过了服务器的处理能力或配置的限制,可能导致读取请求消息时发生异常。可以检查服务器配置和限制,适当调整。 3. 网络问题:网络中断、连接超时等问题可能导致无法完整读取请求消息。可以检查网络连接、防火墙设置等,并确保网络稳定。 4. 客户端异常:某些客户端可能会发送不符合HTTP协议规范的请求消息,或者在请求过程中发生其他异常。可以检查客户端代码和请求消息,确保其正确性。 解决这个问题的方法可能因具体情况而异: - 如果这个异常是由客户端中止连接引起的,并且不会对应用程序产生影响,可以忽略该异常。 - 如果这个异常是由请求过大或网络问题引起的,可以检查服务器配置、网络连接以及请求消息的大小,并进行相应的调整。 - 如果这个异常是由客户端异常引起的,可以检查客户端代码和请求消息,确保其正确性。 需要根据具体情况进行分析和调整,可能需要进一步的排查和调试来确定问题的根本原因。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值