0% found this document useful (0 votes)
44 views5 pages

04.01 - Wireshark - IP - v7.05

Uploaded by

Inês
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
44 views5 pages

04.01 - Wireshark - IP - v7.05

Uploaded by

Inês
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
You are on page 1/ 5

REDES DE COMPUTADORES

7TH LAB – IP
B ASED ON THE L ABS FROM THE BOOK
In this lab, we’ll investigate the IP protocol, focusing on the IP datagram. We’ll do so by analyzing a
trace of IP datagrams sent and received by an execution of the traceroute program (the
traceroute program itself is explored in more detail in the Wireshark ICMP lab). We’ll
investigate the various fields in the IP datagram, and study IP fragmentation in detail.

Before beginning this lab, you’ll probably want to review the textbook and section 3.4 of RFC 2151
[ftp://ftp.rfc-editor.org/in-notes/rfc2151.txt] to update yourself on the operation of the
traceroute program. You’ll probably also have RFC 791 [ftp://ftp.rfc-editor.org/in-
notes/rfc791.txt] on hand as well, for a discussion of the IP protocol.

1. CAPTURING PACKETS FROM AN EXECUTION OF TRACEROUTE


In order to generate a trace of IP datagrams for this lab, we’ll use the traceroute program to
send datagrams of different sizes towards some destination, X. Recall that traceroute operates
by first sending one or more datagrams with the time-to-live (TTL) field in the IP header set to 1; it
then sends a series of one or more datagrams towards the same destination with a TTL value of 2;
it then sends a series of datagrams towards the same destination with a TTL value of 3; and so on.
Recall that a router must decrement the TTL in each received datagram by 1 (actually, RFC 791 says
that the router must decrement the TTL by at least one). If the TTL reaches 0, the router returns
an ICMP message (type 11 – TTL-exceeded) to the sending host. As a result of this behavior, a
datagram with a TTL of 1 (sent by the host executing traceroute) will cause the router one hop
away from the sender to send an ICMP TTL-exceeded message back to the sender; the datagram
sent with a TTL of 2 will cause the router two hops away to send an ICMP message back to the
sender; the datagram sent with a TTL of 3 will cause the router three hops away to send an ICMP
message back to the sender; and so on. In this manner, the host executing traceroute can learn
the identities of the routers between itself and destination X by looking at the source IP addresses
in the datagrams containing the ICMP TTL-exceeded messages.

We’ll want to run traceroute and have it send datagrams of various lengths.

• Windows. The tracert program (used for our ICMP Wireshark lab) provided with
Windows does not allow one to change the size of the ICMP echo request (ping) message
sent by the tracert program. A nicer Windows traceroute program is pingplotter,
available in trial version at http://www.pingplotter.com. Download and install pingplotter,
and test it out by performing a few traceroutes to your favorite sites. The size of the ICMP
echo request message can be explicitly set in pingplotter by selecting the menu item Edit-
> Options->Default Settings->Engine and then filling in the Packet Size field. The default
packet size is 56 bytes. Once pingplotter has sent a series of packets with the increasing
TTL values, it restarts the sending process again with a TTL of 1, after waiting Trace Interval
amount of time. The value of Trace Interval and the number of intervals can be explicitly
set in pingplotter.

• Linux/Unix/macOS. With the Unix/macOS traceroute command, the size of the UDP
datagram sent towards the destination can be explicitly set by indicating the number of
bytes in the datagram; this value is entered in the traceroute command line
immediately after the name or address of the destination. For example, to send
traceroute datagrams of 2000 bytes towards www.ipl.pt, the command would be:

traceroute www.ipl.pt 2000

Do the following:

• Start up Wireshark and begin packet capture (Capture->Start) and then press OK on the
Wireshark Packet Capture Options screen (we’ll not need to select any options here).

• If you are using a Windows platform, start up pingplotter and enter the following target
destination in the “Address to Trace Window.”: 192.68.221.251 1 Select the menu item
Edit->Options->Default Settings->Engine and enter a value of 56 in the Packet Size field and
then press OK. Then press the Trace button. You should see a pingplotter window that
looks something like this:

1
This is the IP address of www.ipl.pt when this lab guide was last updated.
Next, send a set of datagrams with a longer length, by selecting Edit-> Options->Default
Settings->Engine and enter a value of 2000 in the Packet Size field and then press OK. Then
press the Resume button.

Finally, send a set of datagrams with a longer length, by selecting Edit-> Options->Default
Settings->Engine and enter a value of 3500 in the Packet Size field and then press OK. Then
press the Resume button.

Stop Wireshark tracing.

• If you are using a Unix or Mac platform, enter three traceroute commands, one with
a length of 56 bytes, one with a length of 2000 bytes, and one with a length of 3500 bytes,
e.g.:

traceroute 192.68.221.251 56

Stop Wireshark tracing.

2. A LOOK AT THE CAPTURED TRACE


In your trace, you should be able to see the series of ICMP Echo Request (in the case of Windows
machine) or the UDP segment (in the case of Unix) sent by your computer and the ICMP TTL-
exceeded messages returned to your computer by the intermediate routers. In the questions
below, we’ll assume you are using a Windows machine; the corresponding questions for the case
of a Unix machine should be clear.

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?

2. Within the IP packet header, what is the value in the upper layer protocol field?

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.

4. Has this IP datagram been fragmented? Explain how you determined whether or not the
datagram has been fragmented.

Next, sort the traced packets according to IP source address by clicking on the Source column
header; a small downward pointing arrow should appear next to the word Source. If the arrow
points up, click on the Source column header again. Select the first ICMP Echo Request message
sent by your computer, and expand the Internet Protocol portion in the “details of selected packet
header” window. In the “listing of captured packets” window, you should see all of the subsequent
ICMP messages (perhaps with additional interspersed packets sent by other protocols running on
your computer) below this first ICMP. Use the down arrow to move through the ICMP messages
sent by your computer.

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?

6. Which fields stay constant? Which of the fields must stay constant? Which fields must
change? Why?

7. Describe the pattern you see in the values in the Identification field of the IP datagram
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.

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

9. Do these values remain unchanged for all of the ICMP TTL-exceeded replies sent to your
computer by the nearest (first hop) router? Why?

FRAGMENTATION
Sort the packet listing according to time again by clicking on the Time column.

10. 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?

11. 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?

12. 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?

13. What fields change in the IP header between the first and second fragment?

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.

14. How many fragments were created from the original datagram?

15. What fields change in the IP header among the fragments?

You might also like