【tcp】关于 connection reset、connection reset by peer

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了【tcp】关于 connection reset、connection reset by peer相关的知识,希望对你有一定的参考价值。

参考技术A 我们先熟悉一下 tcp 三次握手和四次挥手:

RST的标志位,这个标识为在如下几种情况下会被设置,以下是我了解的情况,可能还有更多的场景,没有验证:

1. 当尝试和未开放的服务器端口建立tcp连接时,服务器tcp将会直接向客户端发送reset报文;

2. 双方之前已经正常建立了通信通道,也可能进行过了交互,当某一方在交互的过程中发生了异常,如崩溃等,异常的一方会向对端发送reset报文,通知对方将连接关闭;

3. 当收到TCP报文,但是发现该报文不是 已建立的TCP连接列表 可处理的,则其直接向对端发送reset报文;

4. ack报文丢失,并且超出一定的重传次数或时间后,会主动向对端发送reset报文释放该TCP连接。

“ Connection reset by peer ”和“ Connection reset” 是有区别的:

服务器返回了“RST”时,如果此时 客户端 正在从Socket套接字的 输出流 中 读数据 则会提示Connection reset”;

服务器返回了“RST”时,如果此时 客户端 正在往Socket套接字的 输入流 中 写数据 则会提示“Connection reset by peer”。

“connection reset by peer”和”broken pipe”出现的场景:

1)往一个对端已经close的通道写数据的时候,对方的tcp会收到这个报文,并且反馈一个reset报文。

当收到reset报文的时候,继续做 select读数据 的时候就会抛出Connect reset by peer的异常。

2)当第一次往一个对端已经close的通道写数据的时候会和上面的情况一样,会收到reset报文。

当再次 往这个socket写数据 的时候,就会抛出Broken pipe了 。

根据tcp的约定,当收到reset包的时候,上层必须要做出处理,调用将socket文件描述符进行关闭,其实也意味着pipe会关闭,因此会抛出这个顾名思义的异常。

Orderly Versus Abortive Connection Release in Java

https://docs.oracle.com/javase/1.5.0/docs/guide/net/articles/connection_release.html

关于 Connection reset原因分析和解决方案

https://my.oschina.net/xionghui/blog/508758

从tcp原理角度理解Broken pipe和Connection Reset by Peer的区别

http://lovestblog.cn/blog/2014/05/20/tcp-broken-pipe

对TCP重传的进一步认识

http://blog.sina.com.cn/s/blog_4d276ac901011ee7.html

https://www.cnblogs.com/YXBLOGXYY/p/14243259.html

以上是关于【tcp】关于 connection reset、connection reset by peer的主要内容,如果未能解决你的问题,请参考以下文章

Dockerread tcp 172.16.11.202:42874->104.18.125.25:443: read: connection reset by peer

重复日志:警告传输连接到 tcp:<ip> failed: java.net.SocketException: Connection reset

fatal: unable to access ‘‘: TCP connection reset by peer

从tcp原理角度理解Broken pipe和Connection Reset by Peer的区别

从tcp原理角度理解Broken pipe和Connection Reset by Peer的区别

Connection reset原因分析及解决思路