Homework3 Solutions
Homework3 Solutions
Homework3 Solutions
Problems
1. TCP (30 p)
Consider a recently established TCP connection between processes PA and PB on hosts A and B,
respectively. The three-way handshake has been done, but no data has been sent yet. TCP on Host
B announced a receiver window size of 5000 bytes to TCP on Host A, and Process PB can read the
received data from TCP as soon as they arrive. Process PA has 15000 bytes to send via TCP. The
path MTU between the two hosts is known to be 1040 bytes. The propagation time is 200ms, and
the link speed is 8Mbps. It takes 1ms for TCP to generate a segment (with or without data) and this
can be done in parallel with sending a previously generated segment.
The receiver uses delayed acknowledgements with a delay of 200ms (or at most two full segments).
The size of a segment having a TCP header only is negligible in terms of transmission time. IP
options are not used. Process PA sends the first segment at time t0 with sequence number ISN+1.
CWND is originally set to 1 MSS and the slow start threshold is 65535 bytes. Assume that the
granularity G of the heartbeat timer is 0.5 seconds.
a) What is the MSS used by TCP?
(3 p)
b) What is the bandwidth-delay product of the communication channel? Is the advertised receiver
window of B big enough? If not, how big should it be for A to be able to fully utilize the
channel?
(7 p)
c) Provide the sequence of segments sent by TCP from host A. For each segment sent from host
A provide the time it is sent, and the sequence number of the first byte it contains. For the first
four segments sent from host A also provides the SRTT, RTTVAR and the RTO values of the
sender TCP at the time the segment is sent. Assume that outgoing segments are handled before
incoming segments in case more than one event happens at the same time!
(15 p)
d) At what time does A receive the acknowledgement for the last segment?
(5 p)
Hint 1: Try to first draw the sequence of segment exchanges to get the order of the segments right.
Hint 2: Consult RFC 2988 for details on how to calculate the SRTT, RTTVAR and the RTO. The
description provided in the course book (3ed and 4ed) is not correct.
Solution
a) MSS=1040-20 (TCP header)-20(IP header)
b) The bandwidth delay product is RTTxBW=0.4*8*10^6bits=3.2*10^6 bits=400KB. Thus, the
received window is not big enough, it should be at least 400KB.
c) After connection establishment RTO=max(2.5+G,3)=3s, this is at t0. SRTT=RTTVAR=0.
The following figure shows the segments sent. Sending time is relative to t0, sequence number
is relative to ISN+1! (ACK+time@x) is the sending time of an acknowledgement with ESN x,
(ACKR+time) is the reception time of an acknowledgement.
+0
ACKR+602
+603
+604
ACKR+1006
+1007
+1008
+1009
ACKR+1410
+1411
+1412
+1413
ACKR+1611
+1612
+1613
ACKR+1814
+1815
+1816
ACKR+2014
+2015
+2016
ACKR+2215
SEQ0
+201
ACK+402@1000
SEQ1000
SEQ2000
+804
+805
SEQ3000
SEQ4000
SEQ5000
+1208
+1209
+1210
SEQ6000
SEQ7000
SEQ8000
SEQ9000
ACK+806@3000
ACK+1210@5000
ACK+1411@6000
SEQ10000
SEQ11000
SEQ12000
SEQ13000
SEQ14000
ACKR+2218
+1612
+1613 ACK+1614@8000
+1614
+1813 ACK+1814@10000
+1814
ACK+2015@11000
+2016
+2017 ACK+2018@13000
+2216
+2217
ACK+2218@15000
ACKR+2418
The SRTT, RTTVAR and RTO values for the first four segments sent by A are:
1) 0, 0, 3 (initial values as given in the RFC)
ACK received at t0+602. Measured RTT=602ms. SRTT=0.602, RTTVAR=0.602/2=0.301.
RTO=SRTT+max(G, 4*RTTVAR)=0.602+1.2=1.806s.
2) 0.602, 0.301, 1.806
3) 0.602, 0.301, 1.806
ACK received at t0+1006. Measured RTT equals 402ms.
RTTVAR=0.75*0.301+0.25*|0.602-0.402|=0.2758,
SRTT=7/8*0.602+1/8*0.402=0.577.
RTO=SRTT+max(G, 4*RTTVAR)=0.577+1.0312 =1.6802s
4) 0.577, 0.2758, 1.6802
Observe that even though the RTT is constant, due to delayed acknowledgements the
RTTVAR is not 0.
d) At t0+2418ms.
Grading suggestions: Important things to consider are whether flow control and congestion
control are correctly accounted for (slow start, and max 5 segments outstanding). Delayed
ACKs are also important, there should be 1 ACK for every two segments or a delay of 200ms.
The 1ms to prepare segments was added to spread out the reception of the segments slightly,
missing it is not a major issue, but the solution should be consistent. Missing the transmission
time (1ms) is a mistake.
2. Mail (25 p)
Consider the scenario when Alice (left) sends an email to Bob (right). There are two intermediate
systems: outgoing mail server and incoming mail server.
Solution
a) If the outgoing mail server is removed, Alices UA needs to contact the incoming mail server
directly in order to send the mail. The incoming mail server may not be able to receive the mail
it could be busy or otherwise unavailable and then Alices UA cannot send the mail, and has
to wait until the incoming mail server becomes available. Hence, the outgoing mail server
offloads Alices UA by queuing messages waiting to be sent.
(An outgoing mail server is also important for controlling the sending of mail from an
organization. It can control what clients are allowed to send mail as a way to prevent abuse,
spam for instance. This is not a required part of the solutions, though, so there is no reduction in points for
not mentioning this.)
b) The incoming mail server stores Bobs mail, and Bob can access the mail whenever he wants. If
the server is removed, Bob has to be online in order to receive mail. (It also means that Bob
will store all mail on his computer, so he cannot access his mail from another computer. No
reduction in points for not mentioning this.)
c) 1: SMTP. 2: SMTP. 3: POP or IMAP (HTTP is also a valid answer, if the UA is web-based).
3. Web (25 p)
Suppose that you click on a link on a web page, which causes the following HTTP request to be
sent. (\r\n denotes carriage return and line feed.)
GET /social HTTP/1.1\r\n
Host: www.kth.se\r\n
Connection: keep-alive\r\n
Cache-Control: max-age=0\r\n
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,*/
*;q=0.8\r\n
User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_8_5)
AppleWebKit/537.36
(KHTML,
like
Gecko)
Chrome/29.0.1547.76
Safari/537.36\r\n
Accept-Encoding: gzip,deflate,sdch\r\n
Accept-Language: en-US,en;q=0.8\r\n
\r\n
a) Which web document does the browser request? Answer by giving the URL.
(3 p)
b) Which version of HTTP is the browser using? What kind of connection is requested, persistent
or non-persistent? (Note that the textbook does not cover header fields related to persistence,
so you may want to consult other resources, on the Internet for example.)
(4 p)
The server gives the following response:
HTTP/1.1 302 Found\r\n
Date: Thu, 26 Sep 2013 20:54:23 GMT\r\n
Server: Apache/2.2.3 (Red Hat)\r\n
Location: https://www.kth.se/social/\r\n
Content-Length: 286\r\n
Connection: close\r\n
Content-Type: text/html; charset=iso-8859-1\r\n
\r\n
more data
Solution
a)
b)
c)
d)
http:/www.kth.se/social
HTTP version 1.1. The browser is requesting a persistent connection.
The server accepts a non-persistent connection.
This response is a normal response when a page is moved. The client is redirected to the new
location, as specified by the Location header. (In this case, the client is redirected from a nonencrypted connection to an encrypted connection, i.e., from a URL with http: to a URL with
https:).
4
e) The transaction involves fetching the main HTML object, and then the three objects it
contains.
1. 8RTT. First one TCP SYN/ACK and one HTTP request/response for the main HTML
object. Then, for each contained object, one TCP SYN/ACK and one HTTP
request/response.
2. 5RTT . One TCP SYN/ACK and then one HTTP request/reply for each object.
f)
1. 4RTT. First one TCP SYN/ACK plus one HTTP request/response for the main HTML
object. Then the contained objects are fetched in parallel, each with a TCP SYN/ACK and
a HTTP request/response.
2. 3RTT. First one TCP SYN/ACK plus one HTTP request/response for the main HTML
object. Then the client uses HTTP pipelining and sends requests for the contained objects
back-to-back, without waiting for responses in between. The responses are returned backto-back.
Grading suggestions: The main thing here is to demonstrate an understanding of how TCP
SYN/ACK and HTTP request/response are combined. In which order are they performed, and
what can be done in parallel? The time it takes to close connections is not relevant, since normally a
client would not block waiting for TCP connection termination. However, no points should be
deducted for taking connection termination into consideration. Incomplete or missing explanations
render deduction in points, though.
4. DHCP (20 p)
Consider the following scenario, where a DHCP client arrives and requests an IP address from the
DCHP server.
A
223.1.1.2
223.1.1.4
223.1.2.9
B
223.1.1.3
223.1.3.1
223.1.2.1
DHCP
server
223.1.1.1
223.1.3.27
223.1.2.2
arriving DHCP
client needs
address in this
network
223.1.3.2
In the simplest case, four DHCP messages will be exchanged according to the figure below. Name
these four DHCP messages (message type) and fill in the missing fields in each message. You can
assume that the subnet to which the DHCP client arrives is a /24 network and that all addresses
below 223.1.2.10 are occupied. Based on that, you can let the DHCP server hand out a suitable IP
address. You also have to select reasonable transaction IDs.
arriving
client
Message 1:
src addr: , src port:
dest addr:, dst port:
yiaddr:
transaction ID:
Message 2:
src addr: , src port:
dest addr:, dst port:
yiaddr:
transaction ID:
Message 3:
src addr: , src port:
dest addr:, dst port:
yiaddr:
transaction ID:
time
Message 4:
src addr: , src port:
dest addr:, dst port:
yiaddr:
transaction ID:
1
Solution
Valid IP addresses for yipaddr from server are 223.1.2.10-223.1.2.254. Transaction ID should be the
same value for DHCP DISCOVER and DHCP OFFER, and a new value to be used in DHCP
REQUEST and DHCP ACK. Some implementations of DHCP actually use the same transaction ID
for all four messages, so such a solution to this problem should also be considered OK.
DHCP
server:
223.1.2.5
arriving
client
DHCP DISCOVER
src : 0.0.0.0, 68
dest.: 255.255.255.255,67
yiaddr: 0.0.0.0
transaction ID: 654
DHCP OFFER
src: 223.1.2.5, 67
dest: 255.255.255.255, 68
yiaddrr: 223.1.2.41
transaction ID: 654
DHCP REQUEST
src: 0.0.0.0, 68
dest:: 255.255.255.255, 67
yiaddrr: 223.1.2.41
transaction ID: 655
time
DHCP ACK
src: 223.1.2.5, 67
dest: 255.255.255.255, 68
yiaddrr: 223.1.2.41
transaction ID: 655
1