《邓哥奇遇记3》——TCP三次握手

你是否经常听别人提起TCP的三次握手和四次挥手呢?你是否看过很多次关于三次握手和四次挥手的文章都没用看懂或是没有记住?
三次握手与四次挥手是计算机行业的一个基本知识点,无论是校招还是社招、无论是前端还是后端都有可能被问到,由于很多同学就要开始准备校招了,那么我们今天就先来聊聊TCP的三次握手。
我们先来聊聊三次握手,我们看到这个问题的时候,第一个疑问是,啥叫握手?俩机器之间怎么还能握手呢?我怎么没发现我家电脑有手?
第二个疑问是,为啥要三次?两次不行吗?我觉得握一下就行了~为啥要握三次?
我们今天先用邓哥的例子,让大家记住三次握手~
话说邓哥的大学生活,用一句话形容那就是:“小树叶过河,全靠浪~”。邓哥在大学时,有一个心目中的女神,绿茶妹妹~
有一天邓哥决定给绿茶妹妹写情书~绿茶妹妹坐在邓哥前面两排的位置,邓哥需要有人帮忙传递小纸条~但是邓哥担心直接传情书的话,前排的同学不帮忙传怎么办?绿茶妹妹收到纸条后不回信怎么办?
这个时候,邓哥和绿茶就相当于是两台要进行通信的主机,但是两台主要要进行通信,要先证明两台主机都有收和发的能力。所以,三次握手主要的目的是为了确认两台主机都具备收和发的能力。
于是邓哥决定先发个小纸条试探一下~于是邓哥写了第一个小纸条:“绿茶~这张纸条的序号是249,我们传条聊天呀~?”。小纸条很顺利的送到了绿茶妹妹的手中~
三次握手实际就是A和B之间发了三条消息~也就是一共传了三张小纸条~现在已经传了一张了~我们假设邓哥是主机A,绿茶是主机B,A需要确认B既可以收也可以发,B也要确认A既可以收也可以发之后,才会开始真正的通信。因为如果有任何一方的收或发存在问题,通信都无法成功。第一张纸条:表示三次握手的第一次握手,主要传递两个信息,一是请求建立连接,二是发出一个序列号。在实际连接中,请求建立连接用SYN=1表示,序列号用seq=n表示,其中n为一个数。在邓哥传条的过程中,邓哥说这条纸条的序号是249,“我们开始传条聊天呀?”就相当于是请求建立连接。第一次握手让B主机知道A可以发出消息
绿茶妹妹回给了邓哥一张小纸条:“hello~收到250的纸条了~这张纸条的序号是99,那我们现在开始聊天?”。然后这张小纸条传递到了邓哥的手中~
这是第二张纸条,也就是第二次握手~我们要注意到邓哥发的序号是249,绿茶回复的是收到250。在实际情况中,这次回复一共有三条信息,一是同意建立连接(SYN = 1),二是确认收到了刚才的信息(ack = 刚才的seq + 1),三是发出自己的序列号(seq = x,其中x为一个数)。在绿茶回复的过程中,“那我们现在开始聊天?”这句话表示同意建立连接。“收到250的纸条了”这句话表示收到了刚才的信息,但是大家要记住,要对刚才的序号做加一处理,所以收到的是249,回复的是250。“这张纸条的序号是99”这句话是绿茶发出的序号。我们仔细想一下,在第一次传条中B知道了A可以发,第二张纸条发出,A接到之后,A知道了B可以接收也能发出。那么这个时候,还有一个没有证明,那就是B还不知道A能不能接收到自己的纸条。虽然A接收到了纸条,但是B并不知道~所以B要生成一个数,让A回复这个数加一才能确认A也能接收到消息。这就是绿茶要发出序号的原因。第二次握手让A知道了B能接收到,也能发出。
邓哥收到了绿茶妹妹回复的纸条之后,发出第三张纸条:“哈哈~收到了序号100,这张纸条的序号是250,现在开聊~”。然后绿茶收到了这张纸条~
这是第三张纸条,也就是第三次握手。这次回复也有三条信息,一是表示现在开始发送(SYN = 0),二是成功收到了绿茶的信息(ack=刚才的seq + 1),三是这张纸条的序号(seq=最开始发出的序号 + 1)。第三次握手让B知道了A能接收到。
那么现在我们有没有清楚为什么不能是两次握手了呢?通过下面这张表可以清楚的看到,第一次握手只能让B知道A能发,第二次握手让A知道了B能收能发,但是这个时候B还不知道A能收,所以A需要发出信息,证明自己收到了B的回复~所以必须要三次才能让两台机器都知道对方能收能发。
*# A(邓哥) B(绿茶妹妹)**
收 第三次握手 第二次握手
发 第一次握手 第二次握手
通过这个例子,大家应该可以理解下面的图示了吧~?

通过三次握手之后,邓哥就可以放心的给绿茶发情书了~
邓哥:“学习很苦,苦海无涯,回头是我~”
绿茶妹妹:“我就喜欢吃苦~”
邓哥:“大哭ing~”
另注:很多互联网公司,当leader在群里发了一个通知之后,很多人在群里回复ack,这个梗的源头就来自于这里。
这就是全部的TCP三次握手的过程~我们下次为大家讲解四次挥手的过程~

原文地址:https://blog.51cto.com/13409950/2472322

时间: 2024-08-01 11:36:57

《邓哥奇遇记3》——TCP三次握手的相关文章

TCP三次握手四次挥手

一.计算机网络体系结构 1.OSI参考模型             2.TCP/IP体系结构        二.TCP三次握手 TCP(Transmission Control Protocol): 传输控制协议. TCP是主机对主机层的传输控制协议,提供可靠的连接服务,采用三次握手来建立一个连接. TCP有6种标志位: 1.SYN(建立连接)      表示同步序号,用来建立连接.SYN标志位和ACK标志位搭配使用,当连接请求的时候,SYN=1,ACK=0:连接被响应的时候,SYN=1,ACK

TCP三次握手及tcpdump抓包

1. TCP报文段的首部格式 说明: ACK : TCP协议规定,只有ACK=1时有效,也规定连接建立后所有发送的报文的ACK必须为1 SYN(SYNchronization) : 在连接建立时用来同步序号.当SYN=1而ACK=0时,表明这是一个连接请求报文.对方若同意建立连接,则应在响应报文中使SYN=1和ACK=1. 因此,  SYN置1就表示这是一个连接请求或连接接受报文 FIN (finis)即完,终结的意思, 用来释放一个连接.当 FIN = 1 时,表明此报文段的发送方的数据已经发

TCP三次握手(建立连接)/四次挥手(关闭连接)

相对于SOCKET开发者,TCP创建过程和链接折除过程是由TCP/IP协议栈自动创建的.因此开发者并不需要控制这个过程.但是对于理解TCP底层运作机制,相当有帮助. 而且对于有网络协议工程师之类笔试,几乎是必考的内容.因此在这里详细解释一下这两个过程. TCP数据包格式 顺序号( 32 位):用来标识从 TCP 源端向 TCP 目的端发送的数据字节流,它表示在这个报文段中的第一个数据字节的顺序号.如果将字节流看作在两个应用程序间的单向流动,则TCP用顺序号对每个字节进行计数.序号是32bit的无

TCP三次握手介绍

TCP(Transmission Control Protocol 传输控制协议)是一种面向连接的.可靠的.基于字节流的传输层通信协议,由IETF的RFC 793定义.在简化的计算机网络OSI模型中,它完成第四层传输层所指定的功能,用户数据报协议(UDP)是同一层内另一个重要的传输协议.在因特网协议族(Internet protocol suite)中,TCP层是位于IP层之上,应用层之下的中间层.不同主机的应用层之间经常需要可靠的.像管道一样的连接,但是IP层不提供这样的流机制,而是提供不可靠

tcp三次握手与四次挥手

开放系统互连参考模型为实现开放系统互连所建立的通信功能分层模型,简称OSI参考模型.其目的是为异种计算机互连提供一个共同的基础和标准框架,并为保持相关标准的一致性和兼容性提供共同的参考.这里所说的开放系统,实质上指的是遵循OSI参考模型和相关协议能够实现互连的具有各种应用目的的计算机系统. 一.    OSI模型七层结构 物理层   位 bit 2.数据链路层  帧 frame 3.网络层 数据包packet/package 4.传输层 网段segmet 5.会话层  message 6.表示层

抓包工具-Wireshark(详细介绍与TCP三次握手数据分析)

功能使用的详细介绍 wireshark(官方下载网站: http://www.wireshark.org/),是用来获取网络数据封包,可以截取各种网络封包,显示网络封包的详细信息,包括http,TCP,UDP,等网络协议包.注:wireshark只能查看封包,而不能修改封包的内容,或者发送封包. 一.开始界面 开始界面,如图1所示: 图1(wireshark开始界面) 点击Caputre->Interfaces,出现图2所示对话框,选择需要捕获网络包的网卡,点击start按钮开始抓包. 注:如果

TCP三次握手和四次挥手

TCP三次握手和四次挥手 在了解TCP三次握手和四次挥手之前我们先来了解一下TCP的标志位,这样有助于我们理解TCP三次握手和四次挥手的过程 TCP标志位: URG:表示TCP包的紧急指针域有效,用来保证TCP连接不被中断 ACK:表示确认序号有效 PSH:表示Push操作; 所谓Push操作就是指在数据包到达接收端以后, 立即传送给应用程序,不在缓冲区排队 RST:表示连接复位请求; 用来复位那些产生错误的连接 SYN:表示同步序号, 用来建立连接;SYN和ACK搭配使用,请求连接时,SYN=

Wireshark 基本介绍和学习 TCP 三次握手

这篇文章介绍另一个好用的抓包工具 Wireshark, 用来获取网络数据封包,包括 HTTP.TCP.UDP 等网络协议包. 记得大学的时候就学习过TCP的三次握手协议,那时候只是知道,虽然在书上看过很多TCP和UDP的资料,但是从来没有真正见过这些数据包, 老是感觉在云上飘一样,学得不踏实.有了wireshark就能截获这些网络数据包,可以清晰的看到数据包中的每一个字段.更能加深我们对网络协议的理解.对我而言, wireshark 是学习网络协议最好的工具. 阅读目录 wireshark介绍

用tcpdump分析tcp三次握手,四次挥手

1.tcpdump 简介 tcpdump是一个对网络上的数据包进行截获的包分析工具,一般linux系统以命令的形式使用 2.tcp三次握手 建立一个tcp连接会发生下面三个过程: 1.服务器必须准备好接受外来的连接,一般是调用socket,bind,listen三个函数完成 2.客户端通过connect主动连接.客户端tcp发送一个SYN,告诉服务器将在连接中发送数据的序列号 3.服务器必须确认(ACK)客户端的SYN,同时发送自己的SYN 4.客户端必须确认服务器的SYN 总共会进行三次数据交

【linux】关于TCP三次握手和四次挥手

1.TCP是什么 关于OSI的七层模型 TCP在第四层——Transport层,第四层的数据叫Segment->报文 IP在第三层——Network层,在第三层上的数据叫Packet->数据包 ARP在第二层——Data Link层:在第二层上的数据,我们把它叫Frame->帧 数据从应用层发下来,会在每一层都会加上头部信息,进行封装,然后再发送到数据接收端,就是每个数据都会经过数据的封装和解封装的过程. wireshark抓到的包与对应的协议层如下图所示 Frame 36441: 物理