请问TCP在三次握手之后传输数据时的问题
请问TCP在三次握手之后,当每次传输数据时,是不是每次传输还要对方确定是否收到?
如果是,那是不是每次传数一次数据,还要来回三次
验证?如果不是,那传输数据是怎么做的?
本帖最后由 Godbach 于 2016-07-10 10:50 编辑
回复 1# netdoger
建议你先看下 TCP/IP 详解中关于TCP协议的介绍,然后再抓包看一下是怎么确认的。
回复 1# netdoger
不是的。
建议看一下Godbach推荐的书,如果懒的看的话,可以这么理解“三次握手之后,进行数据传输的时候,server端发送的数据,client端并不一定是每个包都ack的,可以针对多个包一次ack确认多个”
建议看一下Godbach推荐的书,如果懒的看的话,可以这么理解“三次握手之后,进行数据传输的时候,server端发送的数据,client端并不一定是每个包都ack的,可以针对多个包一次ack确认多个”
=================
那么server段是否还要对client段进行发送确认包ACK呢? 回复 4# netdoger
你要明白TCP既然被称为可靠传输,靠的就是“确认(ack)+重传”
每一个字节都需要确认,这是可靠传输的保证;确认的时机可以灵活,建议看一下网络基础书籍,了解积累确认、捎带确认、发送窗口、拥塞窗口等概念 每次发送数据后,接收端基本上收2次回一个ACK,将这两次的数据全部应该,但是现在的linux可以配置的,多个收包才回ACK,另外还有一个定时器,通过该定时器设定即使收一个包,如果定时器超时,也会回ACK的。 回复 1# netdoger
三次握手是“规规矩矩”的 c向s发syn时间 + s向c发synack时间 + c向s向ack时间。
三次握手之后就不是这样了,比如下载,s向c发送packet1,不必等待收到c的ack,就可以向c发送packet2。
页:
[1]