8.TCP/IP 协议学习笔记

TCP/IP协议详解
本文详细解析了TCP/IP协议中的传输层TCP数据报和网络层IP数据报的结构,并阐述了三次握手建立连接及四次断开的过程。

 

 

一、传输层TCP数据报结构

1、Source Port,表示发起连接的源端口。该部分占16个BIT。通过此值,可以看出发起连接的计算机源端口号。

 

2、Destination Port=21(FTP-CTRL),表示要连接的目的端口为21。该部分占16个BIT。通过此值,可以看出要登录的目的端口号。21端口表示是FTP服务端口。

 

3、Initial Sequence Number=1791872318,表示初始连接的请求号,即SEQ值。该部分占32个BIT,值从1到2的32次方减1。

 

4、Next Expected SEQ Number=1791872319,表示对方的应答号应为1791872319,即对方返回的ACK值。该部分占32个BIT,值从1到2的32次方减1。

 

5、Data Offset=28 Bytes,表示数据偏移的大小。该部分占4个BIT。

 

6、Reserved Bites:保留位,此处不用。该部分占6个BIT。

 

7、Flags=02。该值用两个十六进制数来表示。该部分长度为6个BIT,6个标志位的含义分别是:

              0 URG,紧急数据标志,为1表示有紧急数据,应立即进行传递。

              0 ACK,确认标志位,为1表示此数据包为应答数据包

              0 PSH,PUSH标志位,为1表示此数据包应立即进行传递。

              0 RST:复位标志位。如果收到不属于本机的数据包,则返回一个RST

              0 SYN:连接请求标志位。为1表示为发起连接的请求数据包。

              0 FIN:结束连接请求标志位。为1表示是结束连接的请求数据包。

 

8、Window=64240,表示窗口是64240。该部分占16个BIT。

 

9、CheckSum=92D7(Correct),表示校验和是92D7。该部分占16个BIT,用十六进制表示。

 

10、Urgent Pointer=0,表示紧急指针为0。该部分占16个BIT。

 

11、Maximum Segment Size=1460,表示最大段大小为1460个字节。

 

 

 

二、网络层IP数据报结构

   依次为:

1、Version=4,表示IP协议的版本号为4。该部分占4个BIT位。

 

2、Header Length=20 Bytes,表示IP包头的总长度为20个字节。该部分占4个BIT位,单位为4个字节,因此,一个IP包头的长度最长为“1111”,即15*4=60个字节。

 

3、Type of Service=00,表示服务类型为0。该部分用二个十六进制值来表示,共占8个BIT。

            8个BIT的含义是:

                000 前三位不用

                0 表示最小时延,如Telnet服务使用该位

                0 表示吞吐量,如FTP服务使用该位

                0 表示可靠性,如SNMP服务使用该位

                0 表示最小代价

                0 不用

 

4、Total Length=48Bytes,表示该IP包的总长度为48个字节。该部分占16个BIT,单位为Byte。由此可见,一个IP数据包的最大长度为2的16次方减1,即:65535个字节。因此,在以太网中能够传输的最大IP数据包为65535个字节。

 

5、Identification=363,表示IP包识别号为363。该部分占16个BIT,以十进制数表示。

 

6、Flags,表示片标志,占3个BIT。各位含义分别为:第一个“0”不用,第二个“0”为分片标志位,“1”表示分片,“0”表示不分版本。第三个0为是否最后一片标志位,0表示最后一片,1表示还有更多的片。

 

7、Fragment Offset=0,表示片偏移为0个Bytes。该部分占13个BIT。

 

8、Time to Live=128Secongs/Hops,表示生存时间TTL值为128。该部分占8个BIT。

 

9、Proctol=6(TCP),表示协议类型为TCP,协议代码是6。如果是UDP协议,则此处的协议代码应为17。如果是ICMP协议,则此处的协议代码应为1。该部分占8个BIT。

 

10、Header Checksun=4035(correct),表示IP包头校验和为4035,括号内的Correct表示此IP数据包是正确的,没有被非法修改过。该部分占16个BIT,用十六进制表示。

 

11、Source Address=[76.88.16.104],表示IP数据包源地址为:76.88.16.104。该部分占32个BIT。

 

12、Destination Address=[76.88.16.16],表示IP数据包目的地址为:76.88.16.16。该部分占32个BIT。

 

13、No Options,表示IP数据包中未使用选项部分。

 

 

 

三、三次握手和四次断开

 

ACK TCP报头的控制位之一,对数据进行确认.确认由目的端发出,用它来告诉发送端这个序列号之前的数据段都收到了.比如,确认号为X,则表示前X-1个数据段都收到了,只有当ACK=1,确认号才有效,ACK=0

,确认号无效,这时会要求重传数据,保证数据的完整性.

SYN 同步序列号,TCP建立连接时将这个位置1

FIN 发送端完成发送任务位,TCP完成数据传输需要断开时,提出断开连接的一方将这位置1

 

三次握手:

1 主机A通过向主机B 发送一个含有同步序列号的标志位的数据段给主机B ,向主机B 请求建立连接,通过这个数据段,主机A告诉主机B 两件事:我想要和你通信;你可以用哪个序列号作为起始数据段来回应我.--------SYN

2 主机B 收到主机A的请求后,用一个带有确认应答(ACK)和同步序列号(SYN)标志位的数据段响应主机A,也告诉主机A两件事:我已经收到你的请求了,你可以传输数据了;你要用哪佧序列号作为起始数据段来回应我.------返回ACKSYN

3 主机A收到这个数据段后,再发送一个确认应答,确认已收到主机B 的数据段:"我已收到回复,我现在要开始传输实际数据了.--------再发ACK

有人想是不是当三次握手后,就开始建立了连接了呢?

这就要分请求者和被请求者。请求者是在收到SYNACK后就开始建立连接,而被请求者是在第三次握手后才建立连接。

 

四次断开:

由于TCP连接是全双工的,因此每个方向都必须单独进行关闭。这原则是当一方完成它的数据发送任务后就能发送一个控制位FIN来终 止这个方向的连接。收到一个 FIN只意味着这一方向上没有数据流动,一个TCP连接 在收到一个FIN后仍能发送数据。首先进行关闭的一方将执行主动关闭,而另一方执行被动关闭。

1 当主机A完成数据传输后,将控制位FIN1,提出停止TCP连接的请求

2 主机B收到FIN后对其作出响应,确认这一方向上的TCP连接将关闭,ACK1

3 B 端再提出反方向的关闭请求,FIN1

4 主机A对主机B的请求进行确认,ACK1,双方向的关闭结束.

 

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值