Wireshark Lab: IP v7.0

修改发送数据包的大小
在这里插入图片描述
跟踪的地址为 www.ustc.edu.cn \text{www.ustc.edu.cn} www.ustc.edu.cn
在这里插入图片描述

在这里插入图片描述

由于自己抓的包比较凌乱,分析起来比较复杂,所以使用作者的数据包进行分析

  1. Select the first ICMP Echo Request message sent by your computer, and expand the Internet Protocol part of the packet in the packet details window.What is the IP address of your computer?
    在这里插入图片描述
    IP 192.168.1.102 192.168.1.102 192.168.1.102.

  2. Within the IP packet header, what is the value in the upper layer protocol field?
    上层协议为 ICMP \text{ICMP} ICMP协议
    在这里插入图片描述
    1 1 1 ICMP \text{ICMP} ICMP的协议字段值
    在这里插入图片描述

  3. How many bytes are in the IP header? How many bytes are in the payload of the IP datagram? Explain how you determined the number of payload bytes.
    在这里插入图片描述
    回显请求消息的Header length为20bytesTotal length为84bytes,所以有效负载为64bytes,总长度-报头长度就是有效负载的长度
    在这里插入图片描述
    接收到的消息的Header length为20bytesTotal length为56bytes,所以有效负载为36bytes

  4. Has this IP datagram been fragmented? Explain how you determined whether or not the datagram has been fragmented
    没有分段,因为More fragments标志为not set ,fragment offset:段偏移也为 0 0 0
    在这里插入图片描述

  5. Which fields in the IP datagram always change from one datagram to the next within this series of ICMP messages sent by your computer?

在这里插入图片描述

在这里插入图片描述
标识符(Identification)、存活时间(Time To Live,TTL)、首部检验和 (Header Checksum)在改变

  1. Which fields stay constant? Which of the fields must stay constant? Which fields must change? Why?
    必须保持不变:

    1. 版本(Version):占 4 bit,通信双方使用的版本必须一致,对于 IPv4 字段的值是4;
    2. 首部长度(Internet Header Length, IHL):占 4 bit,首部长度说明首部有多少 32 位字(4字节)。由于IPv4首部可能包含数目不定的选项,这个字段也用来确定数据的偏移量;
    3. 区分服务(Differentiated Services,DS):占 6 bit,只有在使用区分服务时,这个字段才起作用,在一般的情况下都不使用这个字段;

    保持不变:
    1. 显式拥塞通告( Explicit Congestion Notification,ECN):允许在不丢弃报文的同时通知对方网络拥塞的发生。
    2. 全长(Total Length):占 16 位字段,定义了报文总长,包含首部和数据,单位为字节。这个字段的最小值是 20(0 字节数据),最大值是65535。
    3. 标识符(Identification):占16位,这个字段主要被用来唯一地标识一个报文的所有分片,因为分片不一定按序到达,所以在重组时需要知道分片所属的报文。
    4. 分片偏移 (Fragment Offset):这个13位字段指明了每个分片相对于原始报文开头的偏移量,以8字节作单位。
    5. 源地址:报文的发送端;
    6. 目的地址:报文的接收端;
    7. 选项:附加的首部字段可能跟在目的地址之后;
    必须更改:

    1. 标识符(Identification):占 16 位,主要被用来唯一地标识一个报文的所有分片;
    2. 存活时间(Time To Live,TTL):占 8 位,避免报文在互联网中永远存在。实现为跳数计数器,报文经过的每个路由器都将此字段减1,当此字段等于0时,报文不再向下一跳传送并被丢弃,最大值是255。这是traceroute的核心原理;
    3. 首部检验和 (Header Checksum):占 16 位,检验和字段只对首部查错,在每一跳,路由器都要重新计算出的首部检验和并与此字段进行比对,如果不一致,此报文将会被丢弃;
    4. 数据

    所谓的保持不变指的是这次 traceroute 不会改变的,但是下一次 traceroute 可能就会改了。

保持不变必须保持不变必须改变
全长:报文总长,包含首部和数据版本:始终为IPV4标识符:标识所有分片
标识符:唯一地标识一个报文的所有分片首部长度:始终为20存活时间:报文寿命(TTL)
分片偏移:相对于原始报文开头的偏移量区分服务:一般不使用首部检验和 :检验报文是否出错
源地址:报文的发送端上层协议:此处为ICMP数据
目的地址:报文的接收端
选项

在这里插入图片描述

  1. Describe the pattern you see in the values in the Identification field of the IP datagram
    标识符是连续的,并且每次递增1
    在这里插入图片描述

Next (with the packets still sorted by source address) find the series of ICMP TTL exceeded replies sent to your computer by the nearest (first hop) router.

  1. What is the value in the Identification field and the TTL field?

Identification 0x9d7c \text{0x9d7c} 0x9d7cTTL 255 255 255
在这里插入图片描述

  1. Do these values remain unchanged for all of the ICMP TTL-exceeded replies sent to your computer by the nearest (first hop) router? Why
    ID改变,但TTL不变,因为一个路由中的数据包具有相同的寿命,而除分段的数据其他数据包都会有唯一的标识,标识相同表示他们来自同一个数据包的分片
    在这里插入图片描述
    在这里插入图片描述

  2. Find the first ICMP Echo Request message that was sent by your computer after you changed the Packet Size in pingplotter to be 2000. Has that message been fragmented across more than one IP datagram?
    发送 2000 b y t e s 2000bytes 2000bytes的数据后进行了分片,分为了两片

    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述

  3. Print out the first fragment of the fragmented IP datagram. What information in the IP header indicates that the datagram been fragmented? What information in the IP header indicates whether this is the first fragment versus a latter fragment? How long is this IP datagram
    More fragment:Set表示数据报被分段,Fragment Offset:0表示其没有偏移,是第一个分段,这个数据报的长度为 1480+20=1500bytes \text{1480+20=1500bytes} 1480+20=1500bytes
    在这里插入图片描述

  4. Print out the second fragment of the fragmented IP datagram. What information in the IP header indicates that this is not the first datagram fragment? Are the more fragments? How can you tell?
    More fragment:Not set表示数据报不再被分段,即其后不再有分段,Fragment Offset:1480表示其偏移1480,是第二个分段
    在这里插入图片描述

  5. What fields change in the IP header between the first and second fragment?
    Total Length、Flags、Header Checksum 均发生了改变
    数据报分段所以Flags不同、数据内容不同 所以首部检验和改变
    在这里插入图片描述

Now find the first ICMP Echo Request message that was sent by your computer after you changed the Packet Size in pingplotter to be 3500.

  1. How many fragments were created from the original datagram?
    创建了3个 片段
    在这里插入图片描述
  2. What fields change in the IP header among the fragments?

Total Length、Flags、Header Checksum 发生了改变
第一个分片More fragments:Set,fragment offset:0,总长度:1500,
第二个分片More fragments:Set,fragment offset:1480,总长度:1500,
最后一个分片More fragments:Not set,fragment offset:2960,总长度:568;

在这里插入图片描述

在这里插入图片描述

Logo

腾讯云面向开发者汇聚海量精品云计算使用和开发经验,营造开放的云计算技术生态圈。

更多推荐