Warning: foreach() argument must be of type array|object, bool given in /var/www/html/web/app/themes/studypress-core-theme/template-parts/header/mobile-offcanvas.php on line 20

Write a test program that uses the socket interface to send messages between a pair of Unix workstations connected by some LAN (e.g., Ethernet, ATM, or FDDI). Use this test program to perform the following experiments. (a) Measure the round-trip latency of TCP and UDP for different message sizes (e.g., 1 byte, 100 bytes, 200 bytes, ..., 1000 bytes). (b) Measure the throughput of TCP and UDP for 1-KB, 2-KB, 3-KB, ...,32-KB messages. Plot the measured throughput as a function of message size. (c) Measure the throughput of TCP by sending \(1 \mathrm{MB}\) of data from one host to another. Do this in a loop that sends a message of some size, for example, 1024 iterations of a loop that sends 1-KB messages. Repeat the experiment with different message sizes and plot the results.

Short Answer

Expert verified
Write a program to send TCP and UDP messages, measure round-trip latency and throughput for different message sizes, and plot the results.

Step by step solution

01

Set Up Environment

Ensure that two Unix workstations are connected via a LAN (e.g., Ethernet). Both workstations should have the necessary permissions and tools to run socket-based programs.
02

Write the Socket Program

Write a Python program that creates TCP and UDP sockets. The program should be capable of sending and receiving messages. Make sure to include functionality for measuring time intervals to calculate latency and throughput.
03

Measure Round-Trip Latency

For different message sizes (1 byte, 100 bytes, 200 bytes, ..., 1000 bytes), send a message from one workstation to another and wait for the acknowledgment. Record the time taken for each round trip and compute the latency for both TCP and UDP.
04

Measure Throughput for Various Message Sizes

Measure the throughput of TCP and UDP for message sizes of 1 KB, 2 KB, 3 KB, ..., up to 32 KB. To do this, send these messages from one workstation to another and measure the time taken for these messages to be received. Plot the measured throughput as a function of message size.
05

Measure TCP Throughput for 1MB Data

Measure the throughput of TCP by sending 1MB of data in a loop. For instance, send 1024 iterations of 1-KB messages from one workstation to another. Repeat the experiment with different message sizes and record the time taken. Plot the resulting throughput against different message sizes.
06

Analyze and Plot Results

Compile the data gathered from the previous steps. Use plotting software or libraries (such as Matplotlib in Python) to create graphs of latency and throughput as functions of message size for both TCP and UDP.

Key Concepts

These are the key concepts you need to understand to accurately answer the question.

round-trip latency
Round-trip latency refers to the time taken for a message to travel from the sender to the receiver and back again. This includes the network delay for sending the message and the processing time needed at both ends. To measure this in TCP and UDP, you need to record the time just before sending the message and immediately after receiving the acknowledgment.
  • For TCP, the built-in reliability mechanisms ensure that the message is delivered correctly, but this can add to the latency due to the acknowledgment and re-transmission processes.
  • In contrast, UDP offers lower latency because it doesn't guarantee message delivery, thus avoiding additional time spent on acknowledgments and retransmissions.
In your experiment, send messages of different sizes (1 byte, 100 bytes, 200 bytes, up to 1000 bytes) and record the time taken for each round trip. This will help you understand the impact of message size on latency.
TCP throughput
TCP throughput is the rate at which data is successfully transferred over the network using the TCP protocol. Unlike UDP, TCP provides reliable data transfer with acknowledgment of received packets, which impacts throughput.
  • To measure TCP throughput, send large amounts of data (e.g., 1MB) divided into smaller message sizes (e.g., 1 KB, 2 KB, up to 32 KB).
  • Record the time taken to send and acknowledge these packets. The throughput can then be calculated. A higher throughput indicates better performance.
In your tasks, you will measure and plot the throughput for varying message sizes. The result will display how effectively data is transferred over the TCP connection as the message size changes.
UDP throughput
UDP throughput measures how quickly data can be sent using the UDP protocol. Unlike TCP, UDP does not provide reliable data transfer but has lower overheads.
  • In an experiment, you send a large amount of data (e.g., 1MB) divided into smaller message sizes and track the time taken.
  • For UDP, performance is often better for applications that can tolerate some data loss.
  • You measure throughput just like with TCP, but because UDP lacks the reliability checks, its throughput may appear higher.
Compare the UDP and TCP throughput results. This exercise will reinforce the strengths and weaknesses of both protocols in different scenarios.
message size measurement
Measuring message size in network data transfer is crucial for understanding performance metrics like latency and throughput. In your experiments, you'll test a variety of message sizes to observe how each size affects these metrics.
  • Small messages may have low latency but can result in inefficient throughput due to frequent packet processing.
  • Larger messages, while more efficient for throughput, may introduce higher latency.
In your Python program, ensure you correctly measure the size of each message sent. This will help in accurate plotting and analysis of your results. Note that the choice of message size can greatly affect network performance and the insights gathered will help in optimizing applications that depend on socket communication.
Python socket programming
Python socket programming is an effective way to handle network communications in Unix systems. The Python `socket` module provides the necessary functions and classes to create and manage both TCP and UDP connections.
  • To create a TCP socket, use `socket.socket(socket.AF_INET, socket.SOCK_STREAM)`.
  • For a UDP socket, use `socket.socket(socket.AF_INET, socket.SOCK_DGRAM)`.
  • The `send` and `recv` methods handle data transmission and reception for TCP, while `sendto` and `recvfrom` are used for UDP.
Incorporate these into your program to send and measure messages.
Make sure your code includes error handling to manage potential issues like network errors or timeouts. By understanding the basics of Python socket programming, you can efficiently perform the experiments and analyze the gathered data.

One App. One Place for Learning.

All the tools & learning materials you need for study success - in one app.

Get started for free

Most popular questions from this chapter

A sender on a TCP connection that receives a 0 advertised window periodically probes the receiver to discover when the window becomes nonzero. Why would the receiver need an extra timer if it were responsible for reporting that its advertised window had become nonzero (i.e., if the sender did not probe)?

The RPC-based "NFS" remote file system is sometimes considered to have slower than expected write performance. In NFS, a server's RPC reply to a client write request means that the data is physically written to the server's disk, not just placed in a queue. (a) Explain the bottleneck we might expect, even with infinite bandwidth, if the client sends all its write requests through a single logical CHAN channel, and explain why using a pool of channels could help. Hint: You will need to know a little about disk controllers. (b) Suppose the server's reply means only that the data has been placed in the disk queue. Explain how this could lead to data loss that wouldn't occur with a local disk. Note that a system crash immediately after data was enqueued doesn't count because that would cause data loss on a local disk as well. (c) An alternative would be for the server to respond immediately to acknowledge the write request, and to send its own separate CHAN request later to confirm the physical write. Propose different CHAN RPC semantics to achieve the same effect, but with a single logical request/reply.

Consider a SunRPC client sending a request to a server. (a) Under what circumstances can the client be sure its request has executed exactly once? (b) Suppose we wished to add at-most-once semantics to SunRPC. What changes would have to be made? Explain why adding one or more fields to the existing headers would not be sufficient.

Read the man page (or Windows equivalent) for the Unix/Windows utility netstat. Use netstat to see the state of the local TCP connections. Find out how long closing connections spend in TIME_WAIT.

Suppose an idle TCP connection exists between sockets A and B. A third party has eavesdropped and knows the current sequence number at both ends. (a) Suppose the third party sends A a forged packet ostensibly from B and with 100 bytes of new data. What happens? Hint: Look up in Request for Comments 793 what TCP does when it receives an ACK that is not an "acceptable ACK." (b) Suppose the third party sends each end such a forged 100-byte data packet ostensibly from the other end. What happens now? What would happen if \(\mathrm{A}\) later sent 200 bytes of data to B?

See all solutions

Recommended explanations on Computer Science Textbooks

View all explanations

What do you think about this solution?

We value your feedback to improve our textbook solutions.

Study anywhere. Anytime. Across all devices.

Sign-up for free