0%

IP

IP协议与IP流量包检测

9.1 概述

9.1.1 编程目标

捕获一段时间内以本机为源地址或目的地址的IP数据包(不包括广播形式发出的数据包),统计IP数据包的信息,列出本机与其他主机之间不同协议类型的IP数据包的数量

image-20221008011154376

9.1.2 TCP/IP协议族

TCP/IP协议族的分层结构包括应用层,传输层,网络层,链路层

image-20221008011301126

9.1.3 IP协议

IP协议主要负责IP寻址,路由选择,IP数据包的分割与组装,目前常用的是IPv4

IP协议直接位于数据链路层之上,负责将源主机的报文分组发送到目的主机,源主机与目的主机可以位于同一子网

IP协议特点

  • IP协议直接位于数据链路层上,负责将源主机的报文分组发送到目的主机,源主机与目的主机可以位于同一子网内,也可以位于不同子网。
  • IP协议是一种不可靠的、无连接的数据报传送服务协议,它提供的是尽力而为的服务
  • 不可靠:不能保证IP数据包一定能成功到达目的节点。若发生错误,则丢弃该数据报,然后向源主机发送ICMP报文报告错误。可靠性由上层协议提供
  • 无连接:IP协议并不维护数据报发送后的任何状态信息,每个数据报的处理都是相互独立的。不同数据报到达目的节点时可以走不同的路径,IP协议不保证数据传输顺序的正确性

IP协议为了应对各种异构的物理网络,向传输层屏蔽通信子网的差异,IP协议制定了同一的IP数据报格式

9.1.4 IP数据报格式

IP数据报的长度是可变的,它分为报头和数据两个部分。基本的IP报头为20B,选项字段的长度范围是0~40B,所以IP数据报报头的长度范围是20~60B。

image-20221008013342558

版本:4位,表示所使用的IP协议的版本。通信双方使用的IP协议的版本必须已知。版本值为4表示IPv4,版本值为6表示IPv6

报头长度:4位,以4B为单位指定了IP数据报报头长度,该长度不包含数据部分。由于大多数IP报头都不包含选项字段,因此报头长度最少为20B。若报头长度不是4B,则必须利用填充域“填0” 来补充

服务类型:8位,服务类型(type of service,TOS)字段指示了路由器应如何处理该数据包。

image-20221008014812325

4位TOS子字段分别表示:最小延迟(D)、最大吞吐量(T)、最高可靠性(R)和最小费用(C)。每个位都有0或1两个值,但4位中最多只能有一个位的值为1。如果所有4位均为0,那么就意味着是一般服务。由于目前大多数路由器都不支持TOS特性,因此此处填充0即可。

总长度 :16位,总长度域以字节为单位说明包括报头在内的整个IP数据报的总长度。

  • 利用报头长度字段和总长度字段,就可以知道IP数据报中数据内容的起始位置和长度
  • 该字段有16位,所以IP数据包的最大长度可达65535B,但由于以太网MTU(1500B),会进行分片。数据报被分片后,总长度字段的值会发生变化

标识 :16位,用来唯一标识主机发送的每一份数据报,通常每发送一个报文,会加一

当IP数据报必须进行分片时,这个标识域的值会加1。当IP数据报必须进行分片时,这个标识域的值将被复制到所有数据报分片的标识域中。相同的标识域值使各数据报分片后能正确的组装为原始数据报

标志 :3位

  • 第一位保留,并设0

  • 第二位:进制分片标志DF,标识报文是否允许被分片

    0:可以被分片

    1:表示不允许被分片

  • 第三位:分片标志

    只有 DF=0 时该字段才有意义,MF=1 表示后面还有分片的数据报 。MF=0 表示这是若干数据报分片中的最后一个

片偏移 :13位,给出了每一个分片在完整IP数据报中的相对位置。以8B为偏移单位,因此分片的报文,。除了最后一片外,都应是8B的倍数

生存时间 :8位,TTL(time-to-live) 设置了数据报可以经过的最多路由器数。

  • 由源主机设置,一旦经过一个处理它的路由器,其值减1
  • 当TTL=0时,数据报就被对齐,并发送ICMP报文通知源主机

协议 :8位,指出此IP数据报的高层协议类型,以便目的主机的IP层将数据部分上交给那个高层协议处理

image-20221008020515422

头部校验和 :16位,保证数据的完整性,校验不包括数据部分。

  • 每经过一个路由器,就需要重新计算头部校验和(TTL,标志,片偏移)。
  • 为进一步减少计算,校验和不采用复杂的CRC校验码而采用网际校验和算法

源IP地址:32位

目的IP地址:32位

选项:0~40B

-------------本文结束-------------