Description
Exercise 1: Understanding TCP Congestion Control using ns-2
We will first consider TCP Tahoe (this is the default version of TCP in ns-2). Recall that TCP Tahoe uses two mechanisms:
• A varying congestion window, which determines how many packets can be sent before the acknowledgment for the first packet arrives.
• A slow-start mechanism, which allows the congestion window to increase exponentially in the initial phase, before it stabilises when it reaches threshold value. A TCP sender reenters the slow-start state whenever it detects congestion in the network.
The provided script, tpWindow.tcl implements a simple network that is illustrated in the figure below.
Node 0 and Node 1 are connected via a link of capacity 1 Mbps. Data traffic will only flow in the forward direction, i.e. from Node 0 to Node 1. Observe that packets from node 0 are enqueued in a buffer that can hold 20 packets. All packets are of equal size and are equal to the MSS.
The provided script accepts two command line arguments:
• the maximum value of the congestion window at start-up in number of packets (of size MSS).
• The one-way propagation delay of the link
You can run the script as follows:
$ns tpWindow.tcl <max_cwnd> <link_delay>
NOTE: The NAM visualiser is disabled in the script. If you want to display the NAM window (graphical interface), then uncomment the fifth line of the ‘finish’ procedure (i.e. remove the “#”):
proc finish {} { global ns file1 file2 $ns flush-trace close $file1 close $file2
#exec nam out.nam & exit 0
}
We strongly recommend that you read through the script file to understand the simulation setting. The simulation is run for 60 seconds. The MSS for TCP segments is 500 bytes. Node 0 is configured as a FTP sender which transmits a packet every 0.01 second. Node 1 is a receiver (TCP sink). It does not transmit data and only acknowledges the TCP segments received from Node 0.
The script will run the simulation and generate two trace files: (i) Window.tr, which keeps track of the size of the congestion window and (ii) WindowMon.tr , which shows several parameters of the TCP flow.
The Window.tr file has two columns:
time congestion_window_size
A new entry is created in this file every 0.02 seconds of simulation time and records the size of the congestion window at that time. The WindowMon.tr file has six columns:
time number_of_packets_dropped drop_rate throughput queue_size avg_tput
A new entry is created in this file every second of simulation time.
The number_of_packets_dropped , drop_rate and throughput represents the corresponding measured values over each second. The queue_size indicates the size of the queue at each second, whereas avg_tput is the average throughput measured since the start of the simulation.
Question 1: Run the script with the max initial window size set to 150 packets and the delay set to 100ms (be sure to type “ms” after 100). In other words, type the following:
$ns tpWindow.tcl 150 100ms
In order to plot the size of the TCP window and the number of queued packets, we use the provided gnuplot script Window.plot as follows:
$gnuplot Window.plot
What is the maximum size of the congestion window that the TCP flow reaches in this case? What does the TCP flow do when the congestion window reaches this value? Why? What happens next? Include the graph in your submission report.
Answer:
Max windows size is 100, Sender reduce the window size equal to 1. And the threshold be set to half of 100. Because the increasing of windows size, the queue will be full and packets will be drop which make a congestion event(Timeout or triple dup ACK).
Then start another slow-start stage, and increasing until it reach the threshold then do AMID until the queue is full and drop packets again. Then window size go back to 1 and do slow-start again.
Question 2: From the simulation script we used, we know that the payload of the packet is 500 Bytes. Keep in mind that the size of the IP and TCP headers is 20 Bytes, each. Neglect any other headers. What is the average throughput of TCP in this case? (both in number of packets per second and bps)
You can plot the throughput using the provided gnuplot script WindowTPut.plot as follows:
$gnuplot WindowTPut.plot
This will create a graph that plots the instantaneous and average throughput in packets/sec. Include the graph in your submission report.
Answer:
From the graph we can know that average packets per second is 190.
For throughput (include header and payload data): 190 × (500 + 20 + 20) = 102.6𝐾𝐵/𝑆=820.8kbps
For throughput (Only payload data):
190 × (500) = 95000 = 95𝐾𝐵/𝑆= 760kbps
Question 3: Rerun the above script, each time with different values for the max congestion window size but the same RTT (i.e. 100ms). How does TCP respond to the variation of this parameter? Find the value of the maximum congestion window at which TCP stops oscillating (i.e., does not move up and down again) to reach a stable behaviour. What is the average throughput (in packets and bps) at this point? How does the actual average throughput compare to the link capacity (1Mbps)?
Answer:
Max congestion window is 66.
65:
66:
67:
Average throughput:
From graph, we can know that average packet is 225 packet per second.
Average throughput:225 × 500 = 112500 = 112.5 𝐾𝐵/𝑠 = 900 Kbps, which is almost equal to the link capacity (1 Mbps)
TCP Tahoe vs TCP Reno
set tcp0 [new Agent/TCP]
and replace it with:
set tcp0 [new Agent/TCP/Reno]
Question 4: Repeat the steps outlined in Question 1 and 2 (NOT Question 3) but for TCP Reno. Compare the graphs for the two implementations and explain the differences. (Hint: compare the number of times the congestion window goes back to zero in each case). How does the average throughput differ in both implementations?
Answer:
Q1:
Reno only hit zero once and does not enter slow-start stage(expect timeout which at start). When Tahoe meet a congestion event() it will decrease the window size to 1 and enter slow-start stage. But Reno will make current window size half, skip the slow-start stage and increasing linearly when it meets three duplicate ACKs. And repeat until next three duplicate ACKs
Q2:
The Reno average throughput(200 packets/sec) is higher than Tahoe average throughput(190 packets/sec), since the Reno skip the slow_start stage when three duplicate ACKs but Tahoe will set to 1 and do slow start.
Exercise 2: Flow Fairness with TCP
In this exercise, we will study how competing TCP flows with similar characteristics behave when they share a single bottleneck link.
The provided script, tp_fairness.tcl generates 5 source-destination pairs which all share a common network link. Each source uses a single TCP flow which transfers FTP traffic to the respective destination. The flows are created one after the other at 5-second intervals (i.e., flow i+1 starts 5 seconds after flow i for i in [1,4] ). You can invoke the script as follows
$ns tp_fairness.tcl
The figure below shows the resulting topology; there are 5 sources (2,4,6,8,10), 5 destinations (3,5,7,9,11), and each source is sending a large file to a single destination. Node 2 is sending a file to Node 3, Node 4 is sending a file to Node 5, and so on.
The script produces one output file per flow; farinessMon i .tr for each i in [1,5] . Each of these files contains three columns:
time | number of packets delivered so far | throughput (packets per second)
You can plot the throughput as a function of time using the provided gnuplot script, fairness_pkt.plot , as follows:
$gnuplot fairness_pkt.plot
NOTE: The NAM visualiser is disabled in the script. If you want to display the NAM window (graphical interface), modify tp_fairness.tcl and uncomment the fifth line of the ‘finish’ procedure:
proc finish {} { global ns file1 file2 $ns flush-trace close $file1 close $file2
#exec nam out.nam & exit 0
}
Run the above script and plot the throughput as a function of time graph and answer the following questions:
Question 1: Does each flow get an equal share of the capacity of the common link (i.e., is TCP fair) ? Explain which observations lead you to this conclusion.
Answer:
Yes, it is. At start(0 – 20s ) it each flow have different share of capacity of the common link, But when five flows start and as time increased each flow will be 20-40 packets per second. the throughput for all each flow is roughly similar since AIMD congestion control will change window size to achieve long-term fairness if multiple flows share a single bottleneck link. And they all have same network conditions.
Question 2. What happens to the throughput of the pre-existing TCP flows when a new flow is created? Explain the mechanisms of TCP which contribute to this behaviour. Argue about whether you consider this behaviour to be fair or unfair.
Note: Remember to include all graphs in your report.
Answer:
When a new flow is created, the throughput of the per-existing flows will decrease. Because when create new flow, it will do slow-start and create congestion. Other flow will detect the congestion event and decrease the window size to avoid overwhelm. It is fair, since a new flow is add and all flows will have less fair share of capacity of the common link.
Exercise 3: TCP competing with UDP
In this exercise, we will observe how a TCP flow reacts when it has to share a bottleneck link that is also used by a UDP flow.
The provided script, tp_TCPUDP.tcl , takes a link capacity value as a command line argument. It creates a link with the given capacity and creates two flows which traverse that link, one UDP flow and one TCP flow. A traffic generator creates new data for each of these flows at a rate of 4Mbps. You can execute the simulation as follows,
$ns tp_TCPUDP <link_capacity>
After the simulation completes, you can plot the throughput using the provided gnuplot script, TCPUDP_pps.plot , as follows,
$gnuplot TCPUDP_pps.plot
Question 1: How do you expect the TCP flow and the UDP flow to behave if the capacity of the link is 5 Mbps ?
Answer:
Since UDP does not have congestion control but TCP have. The UDP will transmitted at scheduled rate and rest will be TCP.
Now, you can use the simulation to test your hypothesis. Run the above script as follows,
$ns tp_TCPUDP.tcl 5Mb
The script will open the NAM window. Play the simulation. You can speed up the simulation by increasing the step size in the right corner. You will observe packets with two different colours depicting the UDP and TCP flow. Can you guess which colour represents the UDP flow and the TCP flow respectively ?
Answer:
Red is UDP and Blue is TCP
Plot the throughput of the two flows using the above script (TCPUDP_pps.plot) and answer the following questions:
Question 2: Why does one flow achieve higher throughput than the other? Try to explain what mechanisms force the two flows to stabilise to the observed throughput.
Answer:
UDP flow achieve higher throughput than TCP flow. UDP does not have congestion control and it transmitted packets at a constant rate. And UDP does not care about the packet loss. But TCP have congestion control and will change window size based on the network condition which will decrease the transmitted rate.
Question 3: List the advantages and the disadvantages of using UDP instead of TCP for a file transfer, when our connection has to compete with other flows for the same link. What would happen if everybody started using UDP instead of TCP for that same reason?
Note: Remember to include all graphs in your report.
Answer:
Advantages: High transmitting rate and without congestion affect. Less header. Less packets size. Save more time.
When everybody started using UDP it will cause network congestion since UDP does not limit transmitted rate and everyone will get many packets loss since the network is overwhelm. And file maybe broken, performance will worse.
Reviews
There are no reviews yet.