TCP的三次握手和四次挥手

1.是什么

TCP(Transmission Control Protocol 传输控制协议)是一种面向连接的、可靠的、基于字节流的传输层通信协议。  在简化的计算机网络OSI模型中,它完成第四层传输层所指定的功能。


2.为什么学习他

   我们的生活无不无时无刻的站在TCP协议这个“巨人”的肩膀上,最简单的一个打开手机的动作,当你打开浏览器去浏览网站的时候,都是需要建立TCP连接,用来进行数据传输的,当然还是为了让自己对技术有一个更加深入的了解,毕竟万丈高楼平地起嘛。当然面试的时候也经常问到,也是为了高薪哈。(本文也会为大家总结常见的面试题,如果您关心面试,也可以直接从面试问题开始看)


tcp的讲解

虽然TCP是一种计算机网络协议,但本质还是人与人之间的一种约定,只不过由计算机去执行而已,把协议的细节与作用解耦,让我们人类只需专注于基于它的应用呈现之上即可。协议即“规则”,如果我们把光纤“横斜面”剖析,我们看到的就是数据的本质0和1,如下图所示:

0和1是点对点之间通信的信息“载体”,我们需要有一个规则去翻译这些“载体”,好比如发电报,他们约定一个通信密码本进行数据的传输。这些“数据”跟光纤上的“0”和“1”都是承载着一样的任务——信息载体。

要想搞明白TCP协议,我们已经知道他是传输层的协议了,那么我们主要搞明白,TCP的客户端和服务端传输报文的过程和规范,就能把TCP搞明白了。那我们开始,看看TCP的报文和传输流程吧 

报文:

源端口号:我们都知道IP是跟主机相关,而每台主机又可以有不同的应用进程在运行,所以端口更多可以指运行在主机上的应用进程,所以源端口号也就是基于TCP协议传输数据的“发送方”。目的端口:就是等待TCP协议发送方数据的“接收方”,其实所谓的端口也就是应用进程与应用进程之间通信的监听出入口。序列号:这个数字是用来表示通信双方“单向”数据量流动数量表示,上面所介绍的0和1是最小的数据传输单元,我们称为“比特(bit)”。而这个序列号记录的是以“字节”为单位的计数器(1字节=8比特)。例如A要传输给B的512字节数据,假设初始序列号为1024(注意:每次初始化序号都会不一样,TCP有一个比较复杂的初始化算法),那么他们传输过程的序列号为1536。这个序列号会随着双方“交流”而不断的增加,因为序列号一共32比特,所以最大值也就是2^32-1,到达最大值后重新从0开始。因为TCP是一个可靠的协议,序列号的存在是其可靠的关键因素之一。ACK:该位为1时说明确认字段是有效,反之为0。SYN:是一个同步序号,通常与ACK合用用来建立连接。例如SYN=1,ACK=0表示连接请求;SYN=1,ACK=1则表示同意建立连接    其他的部分大家也可以百度搜索到就不说了。

传输:三次握手,四次挥手

咱们前面说TCP是可靠的传输层协议,其实就是因为他的三次握手和四次挥手的数据确定机制。三次握手建立连接第一次握手:发送方首先发起TCP建立连接的请求,SYN=1,ACK=0,seq=x,此时发送方进入并进入SYN_SEND状态,等待服务器确认;   第二次握手:接收端收到SYN,同意建立连接,SYN=1,ACK=1,ack=x+1(对发送方回应的确认字段),seq=y,此时接收端进入此时服务器进入SYN_RECV状态;    第三次握手:发送方收到服务器端发来的同意建立连接的分段,如果此时确认真的要建立连接,则向服务器端发送确认字段,ACK=1,ack=y+1(对接收端做出的回应)。发送方和接收方进入ESTABLISHED状态,完成三次握手 四次挥手解除连接在上面提到了TCP的三次握手建立连接,那仫如何拆除连接呢?就是四次挥手拆除连接。因为TCP的连接时全双工的,所以拆除连接需要拆除两个单向的连接。    第一次挥手:当发送方的主机已经发送完毕的时候,在等待接收端的确认的同时,可以向另一端发送拆除连接的请求。FIN=1,ACK=1,seq=u;(客户端连接解除)    第二次挥手:当接收端已经正确接受发送端的所有数据包,会发送一个ACK应答,同时通知本地相应的应用程序;如果此时对方要求关闭连接,此时再发送一个ACK的分段进行确认。ACK=1,FIN=0,ack=u+1;(服务端连接解除)    第三次挥手:因为TCP的连接时全双工的所以也需要拆除接收方到发送方的连接,此时接收端发送一个FIN的报文段。FIN=1,ACK=1,seq=w;(通信连接解除)    第四次挥手:发送方收到这个FIN字段,发回一个ACK应答。ACK=1,FIN=0,seq=u+1,ack=w+1;(解除确定完毕)


4.面试常见问题

1.TCP和UDP的区别

1、TCP面向连接(如打电话要先拨号建立连接);UDP是无连接的,即发送数据之前不需要建立连接    2、TCP提供可靠的服务。也就是说,通过TCP连接传送的数据,无差错,不丢失,不重复,且按序到达;UDP尽最大努力交付,即不保证可靠    3、TCP面向字节流,实际上是TCP把数据看成一连串无结构的字节流;UDP是面向报文的UDP没有拥塞控制。所以在效率上UDP的传输效率比TCP高    4、每一条TCP连接只能是点到点的;UDP支持一对一,一对多,多对一和多对多的交互通信

2.为什么TCP需要3次握手建立连接,而不是2次,4次以及n次   

其实就是为了保证可靠的通信假设一下如果是两次握手建立连接会发生什仫情况呢?两次握手说明只有请求和应答,假如发送方给接收方发送了一个建立连接的请求,接收方收到了并给发送方做出了ACK应答,然而此时网络不太好,这个应答在回复的路上出了发生了阻塞,延迟了。发送方长时间未收到接收方的回应,认为建立连接失败(但是此时接收方认为连接已经建立好了),于是发送方重新给接收方发送建立连接的请求,此时延迟的ACK应答到达了发送方就会造成网络更加阻塞。而三次握手正好避免了这个问题,如果接收方的ACK应答发生延迟现象,因为是3次握手所以发送方认为自己还没有给接收方发送确认建立连接的字段,所以并不认为连接建立失败,不会重发建立连接的请求;至于为什仫不是4次,以及n次,既然3次握手已经可以成功了建立连接又为什仫要多此一举呢

3.为什么TCP的挥手需要四次

TCP是全双工的连接,必须两端同时关闭连接,连接才算真正关闭。 如果一方已经准备关闭写,但是它还可以读另一方发送的数据。发送给FIN结束报文给对方对方收到后,回复ACK报文。当这方也已经写完了准备关闭,发送FIN报文,对方回复ACK。两端都关闭,TCP连接正常关闭

4.什么是SYN洪水攻击(面试问的不多)

SYN洪水攻击属于DOS攻击的一种,它利用TCP协议缺陷,通过发送大量的半连接请求,耗费CPU和内存资源。


©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 221,820评论 6 515
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 94,648评论 3 399
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 168,324评论 0 360
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 59,714评论 1 297
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 68,724评论 6 397
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 52,328评论 1 310
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,897评论 3 421
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,804评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 46,345评论 1 318
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 38,431评论 3 340
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,561评论 1 352
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 36,238评论 5 350
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,928评论 3 334
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 32,417评论 0 24
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,528评论 1 272
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,983评论 3 376
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 45,573评论 2 359

推荐阅读更多精彩内容

  • 前言: TCP协议是计算机的基础,他本身是一个非常非常复杂的协议。 本文只是蜻蜓点水,将从网络基础以及TCP的相关...
    Janti阅读 612评论 0 4
  • TCP报文格式 TCP提供一种面向连接的,可靠的字节流服务。 TCP首部的数据格式如下。(如果不计任选字段,通常是...
    不变甄心阅读 245评论 0 0
  • TCP协议介绍TCP(Transmission Control Protocol),是一个面向连接的协议,在运用次...
    解忧太后阅读 620评论 0 5
  • 墨色的浓云挤压着这天空,沉沉的仿佛要坠下来,压抑的整个世界都静悄悄的,淡漠的风凌厉的穿梭,柔弱的花草早已战栗地要...
    明舍阅读 424评论 0 1
  • 无聊的周末,和两个小朋友在家追剧――《致我们单纯的小美好》。 故事将十七八岁那段青葱岁月展现出来,好像一切...
    竹本言阅读 219评论 0 1