网络协议之TCP/IP

协议 TCP ip 网络
Angel_YY
发布时间: 2018-06-19
阅读: 1011

现代科技的发展如此之快,移动支付、网络购物、视频直播等各种应用层出不穷,但是这些应用的背后,却有着一个共同的基石做支撑,那就是互联网。而之所以人人都可以接入互联网,标准的网络协议是必不可少的。在互联网发展之初,国际化标准组织ISO定制了一套国际标准OSI(开放式通信系统互联参考模型),在该标准中,网络协议被分为了七层,分别是物理层、数据链路层、网络层、传输层、会话层、表示层、应用层。然而现已成为业界标准协议的TCP/IP协议,并未完全按照OSI模型的七层结构来实现,而是分成了网络接口层、网际层、传输层、应用层四个层次。而事实也证明,四个层次的划分就已经能够非常好的适应现代互联网协议的需求了。


    TCP/IP协议并不是一个协议,而是一系列协议的总称,只是用了其中两个应用最广泛的协议名称来统称这个协议簇了。那么接下来就让我们一起了解一下这个TCP/IP协议簇。

1-TCP协议框架.png


  上图是一个TCP/IP协议的基本框架,当有一个HTTP请求发生时,数据从应用层依次传递给传输层、网际层、网络接口层,并在每一层打包上自己的首部,最终通过电信号传送出去。接收端接收到数据包后,再以相反的顺序解包并依次上传,最终到达应用层去解析HTTP数据。


  下面就以浏览器访问云汉社区网站的一帧数据包为例,了解一下TCP/IP协议。


0002.png


    该数据帧总的结构如图所示:

2-封包过程.png


    接下来分别了解一下各个部分的结构。

  以太网数据包格式为:首部(14字节)+数据(46~1500字节)+4字节CRC

3-以太网帧格式.png


   首部固定为14个字节,包含了目标MAC地址、源MAC地址和数据报类型,MAC地址是一个48(6字节)的物理地址,网卡在出厂时固定死的。


0003.png


    IP数据报格式:

    IP 数据报的首部长度和数据长度都是可变长的,但总是4 字节的整数倍,一般为20字节。


4-IP数据报格式.png 

  

  对于IPv44 位版本字段是44 位首部长度的数值是以4 字节为单位的,最小值为5,也就是说首部长度最小是4x5=20 字节,也就是不带任何选项的IP 首部,4 位能表示的最大值是15,也就是说首部长度最大是60 字节。8 TOS 字段有3 个位用来指定IP 数据报的优先级(目前已经废弃不用),还有4 个位表示可选的服务类型(最小延迟、最大呑吐量、最大可靠性、最小成本),还有一个位总是0。总长度是整个数据报(包括IP 首部和IP payload)的字节数。每传一个IP 数据报,16 位的标识加1,可用于分片和重新组装数据报。3 位标志和13 位片偏移用于分片。TTLTime to live)是这样用的:源主机为数据包设定一个生存时间,比如64,每过一个路由器就把该值减1,如果减到0 就表示路由已经太长了仍然找不到目的主机的网络,就丢弃该包,因此这个生存时间的单位不是秒,而是跳(hop)。协议字段指示上层协议是TCPUDPICMP 还是IGMP。然后是校验和,只校验IP 首部,数据的校验由更高层协议负责。IPv4IP 地址长度为32 位。


 0004.png


    IP数据报承载的内容最常见的是UDPTCP两种数据段,首先来看一下UDP段。

5-UDP段格式.png

    UDP 协议不面向连接,也不保证传输的可靠性。但是因为数据段结构简单,应用也非常广泛。

  接下来重点分析一线TCP段,TCP段首部通常也是20字节。


6-TCP段格式.png



序号:指出段中的数据部分在发送方数据流中的位置。

确认号:指出接收方希望收到对方下次发送的数据的第一个字节的序号。

TCP段首部的定长部分为20个字节,即5个单位的长度。

URG位:紧急标志,和紧急指针配合使用,当其为1时表示,此报文要尽快传送。

ACK位:确认标志,和确认号字段配合使用,当ACK位置1时,确认号字段有效。

PSH位:为推送标志,置1时,发送方将立即发送缓冲区中的数据。

RST位:复位标志,置1时,表明有严重差错,必须释放连接。

SYN位: 同步标志,置1时,表示请求建立连接。

FIN位:终止标志,置1时,表明数据已经发送完,请求释放连接。

窗口大小:32bit,用于向对方通告当前本机的接受缓冲区的大小。

校验和字段长度:16bit,校验范围包括段首部、数据以及伪首部。


0005.png


TCP的传输过程:

7-TCP传输过程.png




建立连接的过程:

1. 客户端发出段1SYN 位表示连接请求。

2】 服务器发出段2,也带有SYN 位,同时置ACK 位表示确认。

3】 客户端发出段3,对服务器的连接请求进行应答。


在这个过程中,客户端和服务器分别给对方发了连接请求,也应答了对方的连接请求,其中服务器的请求和应答在一个段中发出,因此一共有三个段用于建立连接,称为'''三方握手(three-way-handshake'''。在建立连接的同时,双方协商了一些信息,例如双方发送序号的初始值、最大段尺寸等。

TCP数据传输过程:

1】  客户端发出段4,包含N 个字节数据。

2】  服务器发出段5,确认数据收到,服务器在应答的同时也向客户端发送数据。

3】  客户端发出段6,对服务器发来的数据表示确认收到。


在数据传输过程中,ACK 和确认序号是非常重要的,应用程序交给TCP 协议发送的数据会暂存在TCP 层的发送缓冲区中,发出数据包给对方之后,只有收到对方应答的ACK 段才知道该数据包确实发到了对方,可以从发送缓冲区中释放掉了,如果因为网络故障丢失了数据包或者丢失了对方发回的ACK 段,经过等待超时后TCP 协议自动将发送缓冲区中的数据包重发。

TCP连接的关闭

1】  客户端发出段7FIN 位表示关闭连接的请求。

2】  服务器发出段8,应答客户端的关闭连接请求。

3】  服务器发出段9,其中也包含FIN 位,向客户端发送关闭连接请求。

4】  客户端发出段10,应答服务器的关闭连接请求。


建立连接的过程是三方握手,而关闭连接通常需要4 个段(四次握手),服务器的应答和关闭连接请求通常不合并在一个段中,因为有连接半关闭的情况,这种情况下客户端关闭连接之后就不能再发送数据给服务器了,但是服务器还可以发送数据给客户端,直到服务器也关闭连接为止。




原创作品,未经权利人授权禁止转载。详情见转载须知 举报文章

点赞 (0)
Angel_YY 擅长:BMS电池管理系统,用户行为分析系统
评论(0)

登录后可评论,请 登录注册

相关文章推荐
X
你的打赏是对原创作者最大的认可
请选择打赏IC币的数量,一经提交无法退回 !
100IC币
500IC币
1000IC币
自定义
IC币
确定
X
提交成功 ! 谢谢您的支持
返回

我要举报该内容理由

×
请输入您举报的理由(50字以内)