do 有 like you:TCP三次握手及四次挥手详细图解
来源:百度文库 编辑:偶看新闻 时间:2024/05/22 02:00:03
TCP三次握手及四次挥手详细图解
Andrew Huangbluedrum@163.com
相对于SOCKET开发者,TCP创建过程和链接折除过程是由TCP/IP协议栈自动创建的.因此开发者并不需要控制这个过程.但是对于理解TCP底层运作机制,相当有帮助. 而且对于有网络协议工程师之类笔试,几乎是必考的内容.企业对这个问题热情之高,出乎我的意料:-)。有时上午面试前强调这个问题,并重复讲一次,下午几乎每一个人都被问到这个问题。 因此在这里详细解释一下这两个过程。 TCP三次握手 所谓三次握手(Three-way Handshake),是指建立一个TCP连接时,需要客户端和服务器总共发送3个包。 三次握手的目的是连接服务器指定端口,建立TCP连接,并同步连接双方的序列号和确认号并交换 TCP 窗口大小信息.在socket编程中,客户端执行connect()时。将触发三次握手。
- 第一次握手:
客户端发送一个TCP的SYN标志位置1的包指明客户打算连接的服务器的端口,以及初始序号X,保存在包头的序列号(Sequence Number)字段里。
- 第二次握手:
服务器发回确认包(ACK)应答。即SYN标志位和ACK标志位均为1同时,将确认序号(Acknowledgement Number)设置为客户的I S N加1以.即X+1。
- 第三次握手.
客户端再次发送确认包(ACK) SYN标志位为0,ACK标志位为1.并且把服务器发来ACK的序号字段+1,放在确定字段中发送给对方.并且在数据段放写ISN的+1
SYN攻击
在三次握手过程中,服务器发送SYN-ACK之后,收到客户端的ACK之前的TCP连接称为半连接(half-open connect).此时服务器处于Syn_RECV状态.当收到ACK后,服务器转入ESTABLISHED状态.
Syn攻击就是 攻击客户端 在短时间内伪造大量不存在的IP地址,向服务器不断地发送syn包,服务器回复确认包,并等待客户的确认,由于源地址是不存在的,服务器需要不断的重发直 至超时,这些伪造的SYN包将长时间占用未连接队列,正常的SYN请求被丢弃,目标系统运行缓慢,严重者引起网络堵塞甚至系统瘫痪。
Syn攻击是一个典型的DDOS攻击。检测SYN攻击非常的方便,当你在服务器上看到大量的半连接状态时,特别是源IP地址是随机的,基本上可以断定这是一次SYN攻击.在Linux下可以如下命令检测是否被Syn攻击
netstat -n -p TCP | grep SYN_RECV
一般较新的TCP/IP协议栈都对这一过程进行修正来防范Syn攻击,修改tcp协议实现。主要方法有SynAttackProtect保护机制、SYN cookies技术、增加最大半连接和缩短超时时间等.
但是不能完全防范syn攻击。
TCP 四次挥手
TCP的连接的拆除需要发送四个包,因此称为四次挥手(four-way handshake)。客户端或服务器均可主动发起挥手动作,在socket编程中,任何一方执行close()操作即可产生挥手操作。
参见wireshark抓包,实测的抓包结果并没有严格按挥手时序。我估计是时间间隔太短造成。
请问tcp中的断开连接为甚么要是四次握手而不合并为三次握手?
TCP/IP的三次握手的过程原理
在TCP三次握手过程中,是三次握手后开始传送数据,还是在第三次握手时已经携带数据了?
TCP的三次握手过程是如何进行的?如果握手不成功,会出现什么样的情况?
为什么Ethereal抓的tcp三次握手数据包发起的seq=0呢?
国共三次握手的意义
SEQ在三次握手是什么意思?
建立tcp连接需要几次握手?
请帮解释"三次握手"
继电器的工作原理及图解?在哪里能下载到详细的资料?
请问有没有人有人体手臂及手部神经的详细图解阿
TCP握手中,缩写RST指的是什么?
完全安装WINDOWS详细图解
哪里有电脑键盘的详细图解啊?要有各键及组合键使用的说明.
以色列建国及四次中东战争?
电脑2000系统装机步骤及图解
全新安装 Windows XP详细图解
军体拳第一套详细图解
安装windows2000的详细过程图解
怎样用bt下载,详细,有图解
武林群侠传详细图解功略
打印机端口bois设置详细图解
小圆柱横放用手指向下按中间,圆柱先向前滚逐渐停下后又往回滚,急征详细原理及图解?
Nokia开机握手动画的由来及含义?