Source : https://gaia.cs.umass.edu/kurose_ross/knowledgechecks/index.php
Suggestion : Use light mode for better view of PNG files
- The following descriptions correspond to a "nuts-and-bolts" view of the Internet:
- A "network of networks".
- A collection of billions of computing devices, and packet switches interconnected by links.
- A collection of hardware and software components executing protocols that define the format and the order of messages exchanged between two or more communicating entities, as well as the actions taken on the transmission and/or receipt of a message or other event.
- The following descriptions correspond to a "services" view of the Internet:
- A platform for building network applications.
- A place I go for information, entertainment, and to communicate with people.
- The following human scenarios involve a protocol:
- A student raising her/his hand to ask a really insightful question, followed by the teacher acknowledging the student, listening carefully to the question, and responding with a clear, insightful answer. And then thanking the student for the question, since teachers love to get questions.
- One person asking, and getting, the time to/from another person.
- Two people introducing themselves to each other.
-
Ethernet : Wired. Up to 100's Gbps per link.
802.11 WiFi : Wireless. 10's to 100's of Mbps per device
Cable access network : Wired. Up to 10's to 100's of Mbps downstream per user
Digital Subscriber Line : Wired. Up to 10's of Mbps downstream per user
4G cellular LTE : Wireless. Up to 10's Mbps per device.
-
Which of the following physical layer technologies has the highest transmission rate and lowest bit error rate in practice?
Fiber optic cable
-
Choose one the following two definitions that makes the correct distinction between routing versus forwarding.
Forwarding is the local action of moving arriving packets from router’s input link to appropriate router output link, while routing is the global action of determining the source-destination paths taken by packets.
-
Which of the characteristics below are associated with the technique of packet switching? Select all correct answers. [Hint: more than one of the answers is correct].
- This technique is used in the Internet.
- Data may be queued before being transmitted due to other user's data that's also queueing for transmission.
- Congestion loss and variable end-end delays are possible with this technique.
- Resources are used on demand, not reserved in advance.
-
Which of the characteristics below are associated with the technique of circuit switching? Select all correct answers. [Hint: more than one of the answers is correct].
- This technique was the basis for the telephone call switching during the 20th century and into the beginning of this current century.
- Reserves resources needed for a call from source to destination.
- Frequency Division Multiplexing (FDM) and Time Division Multiplexing (TDM) are two approaches for implementing this technique.
-
Consider the circuit-switched network shown in the figure below, with four circuit switches A, B, C, and D. Suppose there are 20 circuits between A and B, 19 circuits between B and C, 15 circuits between C and D, and 16 circuits between D and A.
What is the maximum number of connections that can be ongoing in the network at any one time?[Note: you can find more questions like this one here.
70
-
Perform a traceroute from your computer (on whatever network you happen to be on) to gaia.cs.umass.edu. Use traceroute (on Mac terminal) or tracert (on Windows command line) or tracepath (on a Linux command line). Enter the missing part of the name of the router just before the host gaia.cs.umass.edu is reached:
??.cs.umass.edu
Note: Routing may change, so the answer here may not be correct anymore. Also, if you are a Verizon user, there are known problems using traceroute with Verizon - if traceroute shows you two hops only to gaia.cs.umass.edu or any destination, skip this question.
nscs1bbs1
-
When we say that the Internet is a "network of networks," we mean? Check all that apply (hint: check two or more).
- The Internet is made up of a lot of different networks that are interconnected to each other.
- The Internet is made up of access networks at the edge, tier-1 networks at the core, and interconnected regional and content provider networks as well.
-
Consider a scenario in which 5 users are being multiplexed over a channel of 10 Mbps. Under the various scenarios below, match the scenario to whether circuit switching or packet switching is better.
- Each user generates traffic at an average rate of 2.1 Mbps, generating traffic at a rate of 15 Mbps when transmitting: Neither works well in this overload scenario
- Each user generates traffic at an average rate of 2 Mbps, generating traffic at a rate of 2 Mbps when transmitting.: Circuit switching
- Each user generates traffic at an average rate of 0.21 Mbps, generating traffic at a rate of 15 Mbps when transmitting.: Packet switching
-
Match the description of each component of packet delay to its name in the pull down list.
- Time needed to perform an integrity check, lookup packet information in a local table and move the packet from an input link to an output link in a router.: Processing delay
- Time spent waiting in packet buffers for link transmission.: Queueing delay
- Time spent transmitting packets bits into the link.: Transmission delay
- Time need for bits to physically propagate through the transmission medium from end one of a link to the other.: Propagation delay
-
Suppose a packet is L = 1500 bytes long (one byte = 8 bits), and link transmits at R = 1 Gbps (i.e., a link can transmit bits 1,000,000,000 bits per second). What is the transmission delay for this packet? [Note: you can find more problems like this one here.]
.000012 secs
-
Suppose a packet is L = 1200 bytes long (one byte = 8 bits), and link transmits at R = 100 Mbps (i.e., a link can transmit bits 100,000,000 bits per second). What is the transmission delay for this packet? [Note: you can find more problems like this one here.]
.000096 secs
-
Consider the network shown in the figure below, with three links, each with the specified transmission rate and link length. Assume the length of a packet is 8000 bits.What is the transmission delay at link 2? [Note: you can find more problems like this one here.]
8 x 10^(-5) secs
-
Consider the network shown in the figure below, with three links, each with the specified transmission rate and link length. Assume the length of a packet is 8000 bits. The speed of light propagation delay on each link is 3x10^8 m/secWhat is the propagation delay at (along) link 2?
.0033 secs
-
What is the maximum throughput achievable between sender and receiver in the scenario shown below?
1.5 Mbps
-
Consider the scenario shown below, with four different servers connected to four different clients over four three-hop paths. The four pairs share a common middle hop with a transmission capacity of R = 300 Mbps. The four links from the servers to the shared link have a transmission capacity of RS = 50 Mbps. Each of the four links from the shared middle link to a client has a transmission capacity of RC = 90 Mbps.What is the maximum achievable end-end throughput (an integer value, in Mbps) for each of four client-to-server pairs, assuming that the middle link is fairly shared (divides its transmission rate equally) and all servers are trying to send at their maximum rate?Your answer: [A] Mbps
50
-
Consider the scenario shown below, with four different servers connected to four different clients over four three-hop paths. The four pairs share a common middle hop with a transmission capacity of R = 300 Mbps. The four links from the servers to the shared link have a transmission capacity of RS = 50 Mbps. Each of the four links from the shared middle link to a client has a transmission capacity of RC = 90 Mbps.
Assuming that the servers are all sending at their maximum rate possible, what are the link utilizations for the server links (with transmission capacity RS)? Enter your answer in a decimal form of 1.00 (if the utilization is 1) or 0.xx (if the utilization is less than 1, rounded to the closest xx).Your answer: The utilization of the server links is: [A]
1.00
-
Consider the scenario shown below, with four different servers connected to four different clients over four three-hop paths. The four pairs share a common middle hop with a transmission capacity of R = 300 Mbps. The four links from the servers to the shared link have a transmission capacity of RS = 50 Mbps. Each of the four links from the shared middle link to a client has a transmission capacity of RC = 90 Mbps.
Assuming that the servers are all sending at their maximum rate possible, what are the link utilizations of the shared link (with transmission capacity R)? Enter your answer in a decimal form of 1.00 (if the utilization is 1) or 0.xx (if the utilization is less than 1, rounded to the closest xx).Your answer: The utilization of shared link is: [A]
0.67
-
Consider the scenario shown below, with four different servers connected to four different clients over four three-hop paths. The four pairs share a common middle hop with a transmission capacity of R = 300 Mbps. The four links from the servers to the shared link have a transmission capacity of RS = 50 Mbps. Each of the four links from the shared middle link to a client has a transmission capacity of RC = 90 Mbps.
Assuming that the servers are all sending at their maximum rate possible, what are the link utilizations of the client links (with transmission capacity RC)? Enter your answer in a decimal form of 1.00 (if the utilization is 1) or 0.xx (if the utilization is less than 1, rounded to the closest xx).Your answer: The utilization of client link is: [A]
0.56
-
Match the function of a layer in the Internet protocol stack to its its name in the pulldown menu.
- Protocols that are part of a distributed network application.: Application Layer
- Transfer of data between one process and another process (typically on different hosts).: Transport layer
- Delivery of datagrams from a source host to a destination host (typically).: Network layer
- Transfer of data between neighboring network devices.: Link layer
- Transfer of a bit into and out of a transmission media.: Physical layer
-
Match the name of an Internet layer with unit of data that is exchanged among protocol entities at that layer, using the pulldown menu.
- Application layer: Message
- Transport layer: Segment
- Network layer: Datagram
- Link layer: Frame
- Physical layer: Bit
-
Consider the figure below, showing a link-layer frame heading from a host to a router. There are three header fields shown. Match the name of a header with a header label shown in the figure.
- Header H1: Link layer
- Header H2: Network Layer
- Header H3: Transport layer
-
Which of the definitions below describe what is meant by the term "encapsulation"?
Taking data from the layer above, adding header fields appropriate for this layer, and then placing the data in the payload field of the "packet" for that layer.
- Match the description of a security defense with its name.
- Specialized "middleboxes" filtering or blocking traffic, inspecting packet contents inspections: Firewall
- Provides confidentiality by encoding contents: Encryption
- Used to detect tampering/changing of message contents, and to identify the originator of a message.: Digital Signatures
- Limiting use of resources or capabilities to given users.: Access Control
- Proving you are who you say you are.: Authentication
- Match the networking event with the time frame when the event occurred.
- Early studies of packet switching by Baran, Davies, Kleinrock.: Early 1960's
- First ARPAnet node operational.: Late 1960's
- Internetting: DARPA researchers connect three networks together.: 1970's
- The Internet Protocol (IP) is standardized in RFC 791.: Early 1980's
- Congestion control is added to the TCP protocol.: Late 1980's
- The WWW starts up (note: the WWW design started at the end of previous decade).: 1990's
- Software-defined networking begins.: 2000-2010
- The number wireless Internet-connected devices surpasses the number of connected wired devices.: 2010 - 2020
- Which of the characteristics below are associated with a client-server approach to structuring network applications (as opposed to a P2P approach)?
- There is a server that is always on.
- HTTP uses this application structure.
- There is a server with a well known server IP address.
- Which of the characteristics below are associated with a P2P approach to structuring network applications (as opposed to a clienht-server approach)?
- There is not a server that is always on.
- A process requests service from those it contacts and will provide service to processes that contact it.
- When an application uses a UDP socket, what transport services are provided to the application by UDP? Check all that apply.
- Best effort service. The service will make a best effort to deliver data to the destination but makes no guarantees that any particular segment of data will actually get there.
- When an application uses a TCP socket, what transport services are provided to the application by TCP? Check all that apply.
- Loss-free data transfer. The service will reliably transfer all data to the receiver, recovering from packets dropped in the network due to router buffer overflow.
- Congestion control. The service will control senders so that the senders do not collectively send more data than links in the network can handle.
- Flow Control. The provided service will ensure that the sender does not send so fast as to overflow receiver buffers.
-
What do we mean when we say "HTTP is stateless"? In answering this question, assume that cookies are not used. Check all answers that apply.
- An HTTP server does not remember anything about what happened during earlier steps in interacting with this HTTP client.
-
What is an HTTP cookie used for?
A cookie is a code used by a server, carried on a client’s HTTP request, to access information the server had earlier stored about an earlier interaction with this Web browser. [Think about the distinction between a browser and a person.]
-
What is the purpose of the HTTP GET message?
The HTTP GET request message is used by a web client to request a web server to send the requested object from the server to the client.
-
What is the purpose of the conditional HTTP GET request message?
To allow a server to only send the requested object to the client if this object has changed since the server last sent this object to the client.
-
Suppose a client is sending an HTTP GET request message to a web server, gaia.cs.umass.edu. Suppose the client-to-server HTTP GET message is the following:
GET /kurose_ross_sandbox/interactive/quotation2.htm HTTP/1.1 Host: gaia.cs.umass.edu Accept: text/plain, text/html, text/xml, image/jpeg, image/gif, audio/mpeg, audio/mp4, video/wmv, video/mp4, Accept-Language: en-us, en-gb;q=0.1, en;q=0.7, fr, fr-ch, da, de, fi If-Modified-Since: Wed, 09 Sep 2020 16:06:01 -0700 User Agent: Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/535.11 (KHTML, like Gecko) Chrome/17.0.963.56 Safari/535.11 What version of HTTP is the client using?
1.1
-
Again, suppose a client is sending an HTTP GET request message to a web server, gaia.cs.umass.edu. The client-to-server HTTP GET message is the following
What is the language in which the client would least prefer to get a response? [You may have to search around the Web a bit to answer this.]
United Kingdom English
-
Again, suppose a client is sending an HTTP GET request message to a web server, gaia.cs.umass.edu. Suppose the client-to-server HTTP GET message is the following (same as in previous problem)
Does the client have a cached copy of the object being requested?[Note: you can find additional questions similar to this here.]
Yes, because this is a conditional GET, as evidenced by the If-Modified-Since field.
-
Suppose now the server sends the following HTTP response message the client:
HTTP/1.0 200 OK Date: Wed, 09 Sep 2020 23:46:21 +0000 Server: Apache/2.2.3 (CentOS) Last-Modified: Wed, 09 Sep 2020 23:51:41 +0000 ETag:17dc6-a5c-bf716880. Content-Length: 418 Connection: Close Content-type: image/html
Will the web server close the TCP connection after sending this message?[Note: you can find more questions like this one here.]
Yes, the server will close this connection because version 1.0 of HTTP is being used, and TCP connections do not stay open persistently.
-
Which of the following are advantages of using a web cache? Sselect one or more answers.
- Caching uses less bandwidth coming into an institutional network where the client is located, if the cache is also located in that institutional network.
- Caching generally provides for a faster page load time at the client, if the web cache is in the client's institutional network, because the page is loaded from the nearby cache rather than from the distant server.
-
Which of the following are changes between HTTP 1.1 and HTTP/2? Note: select one or more answers.
- HTTP/2 allows a large object to be broken down into smaller pieces, and the transmission of those pieces to be interleaved with transmission other smaller objects, thus preventing a large object from forcing many smaller objects to wait their turn for transmission.
- HTTP/2 allows objects in a persistent connection to be sent in a client-specified priority order.
-
Which of the following pieces of information will appear in a server's application-level HTTP reply message? (Check all that apply.)
- A response code
- A response phrase associated with a response code
-
What is the purpose of the If-Modified-Since field in a HTTP GET request message
To indicate to the server that the client has cached this object from a previous GET, and the time it was cached.
-
What is the purpose of a cookie value in the HTTP GET request?
The cookie value itself doesn't mean anything. It is just a value that was returned by a web server to this client during an earlier interaction.
-
Suppose a client is sending an HTTP GET message to a web server, gaia.cs.umass.edu. Suppose the client-to-server HTTP GET message is the following:
GET /kurose_ross_sandbox/interactive/quotation2.htm HTTP/1.1 Host: gaia.cs.umass.edu Accept: text/plain, text/html, text/xml, image/jpeg, image/gif, audio/mpeg, audio/mp4, video/wmv, video/mp4, Accept-Language: en-us, en-gb;q=0.1, en;q=0.7, fr, fr-ch, da, de, fi If-Modified-Since: Wed, 09 Sep 2020 16:06:01 -0700 User Agent: Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/535.11 (KHTML, like Gecko) Chrome/17.0.963.56 Safari/535.11Does the client have a cached copy of the object being requested?
Yes, because this is a conditional GET.
-
Suppose an HTTP server sends the following HTTP response message a client:
HTTP/1.0 200 OK Date: Wed, 09 Sep 2020 23:46:21 +0000 Server: Apache/2.2.3 (CentOS) Last-Modified: Wed, 09 Sep 2020 23:51:41 +0000 ETag:17dc6-a5c-bf716880. Content-Length: 418 Connection: Close Content-type: image/html
Will the web server close the TCP connection after sending this message?
Yes, because this is HTTP 1.0
-
How many RTTs are there from when a client first contacts an email server (by initiating a TCP session) to when the client can begin sending the email message itself - that is following all initial TCP or SMTP handshaking required?Recall the figure below from our class notes:
3
-
Which of the following characteristics apply to HTTP only (and do not apply to SMTP)? Note: check one or more of the characteristics below.
- Uses a blank line (CRLF) to indicate end of request header.
- Operates mostly as a "client pull" protocol.
- Uses server port 80.
-
Which of the following characteristics apply to SMTP only (and do not apply to HTTP)? Note: check one or more of the characteristics below.
- Uses CRLF.
- CRLF to indicate end of message.
- Operates mostly as a "client push" protocol.
- Uses server port 25.
-
Which of the following characteristics apply to both HTTP and SMTP? Note: check one or more of the characteristics below.
- Is able to use a persistent TCP connection to transfer multiple objects.
- Has ASCII command/response interaction, status codes.
-
Match the functionality of a protocol with the name of a the email protocol (if any) that implements that functionality.
- Pushes email from a mail client to a mail server.:SMTP
- Pulls mail from one mail server to another mail server.: Neither
- Pulls email to a mail client from a mail server.: IMAP
-
Provides authoritative hostname to IP mappings for organization’s named hosts.
- Provides authoritative hostname to IP mappings for organization's named hosts.: Authoritative DNS server
- Replies to DNS query by local host, by contacting other DNS servers to answer the query.: Local DNS server
- Responsible for a domain (e.g., .com, .edu); knows how to contact authoritative name servers.: Top Level Domain (TLD) servers
- Highest level of the DNS hierarchy, knows how to reach servers responsible for a given domain (e.g., .com, .edu).: DNS root servers
-
What is the value of caching in the local DNS name server? Check all that apply.
- DNS caching provides for faster replies, if the reply to the query is found in the cache.
- DNS caching results in less load elsewhere in DNS, when the reply to a query is found in the local cache
-
What information does the type "A" resource record hold in the DNS database? Check all that apply.
A hostname and an IP address.
-
Suppose that the local DNS server caches all information coming in from all root, TLD, and authoritative DNS servers for 20 time units. (Thus, for example, when a root server returns the name and address of a TLD server for .com, the cache remembers that this is the TLD server to use to resolve a .com name). Assume also that the local cache is initially empty, that iterative DNS queries are always used, that DNS requests are just for name-to-IP-address translation, that 1 time unit is needed for each server-to-server or host-to-server (one way) request or response, and that there is only one authoritative name server (each) for any .edu or .com domain.
Consider the following DNS requests, made by the local host at the given times:
- t=0, the local host requests that the name gaia.cs.umass.edu be resolved to an IP address.
- t=1, the local host requests that the name icann.org be resolved to an IP address.
- t=5, the local host requests that the name cs.umd.edu be resolved to an IP address. (Hint: be careful!)
- t=10, the local host again requests that the name gaia.cs.umass.edu be resolved to an IP address.
- t=12, the local host requests that the name cs.mit.edu be resolved to an IP address.
- t=30, the local host again requests that the name gaia.cs.umass.edu be resolved to an IP address. (Hint: be careful!)
Which of the requests require 8 time units to be resolved?
- The request at t=0.
- The request at t=1.
- The request at t=30.
-
[This question is the same as an earlier question, except for the question statement at the very end.] Suppose that the local DNS server caches all information coming in from all root, TLD, and authoritative DNS servers for 20 time units. (Thus, for example, when a root server returns the name and address of a TLD server for .com, the cache remembers that this is the TLD server to use to resolve a .com name). Assume also that the local cache is initially empty, that iterative DNS queries are always used, that DNS requests are just for name-to-IP-address translation, that 1 time unit is needed for each server-to-server or host-to-server (one way) request or response, and that there is only one authoritative name server (each) for any .edu or .com domain.
Consider the following DNS requests, made by the local host at the given times:
- t=0, the local host requests that the name gaia.cs.umass.edu be resolved to an IP address.
- t=1, the local host requests that the name icann.org be resolved to an IP address.
- t=5, the local host requests that the name cs.umd.edu be resolved to an IP address. (Hint: be careful!)
- t=10, the local host again requests that the name gaia.cs.umass.edu be resolved to an IP address.
- t=12, the local host requests that the name cs.mit.edu be resolved to an IP address.
- t=30, the local host again requests that the name gaia.cs.umass.edu be resolved to an IP address. (Hint: be careful!)
Which of the requests require 6 time units to be resolved?
- The request at t=5.
- The request at t=12.
-
[This question is the same as an earlier question, except for the question statement at the very end.] Suppose that the local DNS server caches all information coming in from all root, TLD, and authoritative DNS servers for 20 time units. (Thus, for example, when a root server returns the name and address of a TLD server for .com, the cache remembers that this is the TLD server to use to resolve a .com name). Assume also that the local cache is initially empty, that iterative DNS queries are always used, that DNS requests are just for name-to-IP-address translation, that 1 time unit is needed for each server-to-server or host-to-server (one way) request or response, and that there is only one authoritative name server (each) for any .edu or .com domain.
Consider the following DNS requests, made by the local host at the given times:
- t=0, the local host requests that the name gaia.cs.umass.edu be resolved to an IP address.
- t=1, the local host requests that the name icann.org be resolved to an IP address.
- t=5, the local host requests that the name cs.umd.edu be resolved to an IP address. (Hint: be careful!)
- t=10, the local host again requests that the name gaia.cs.umass.edu be resolved to an IP address.
- t=12, the local host requests that the name cs.mit.edu be resolved to an IP address.
- t=30, the local host again requests that the name gaia.cs.umass.edu be resolved to an IP address. (Hint: be careful!)
Which of the requests require 2 time units to be resolved?
- The request at t=10.
-
Check all of the phrases below that state a true property of a local DNS server.
- The local DNS server can decrease the name-to-IP-address resolution time experienced by a querying local host over the case when a DNS is resolved via querying into the DNS hierarchy.
- The local DNS server record for a remote host is sometimes different from that of the authoritative server for that host.
-
What is the role of an authoritative name server in the DNS? (Check all that apply)
It provides the definitive answer to the query with respect to a name in the authoritative name server's domain.
-
We learned that in HTTP web browser caching, HTTP local web server caching, and in local DNS caching, that a user benefits (e.g., shorter delays over the case of no caching) from finding a local/nearby copy of a requested item. In which of the following forms of caching does a user benefit from its not only from its own recent requests (and cached replies) but also from recent requests made from other users?
- Local DNS server caching
- HTTP local web caching
-
Manifest file. What is the purpose of a manifest file in a streaming multimedia setting?
To let a client know where it can retrieve different video segments, encoded at different rates
-
What approach is taken by a CDN to stream content to hundreds of thousands of simultaneous users?
Store/serve multiple copies of videos at multiple geographically distributed sites.
-
Match the definition/function of an element or approach in a networked streaming video system, with its name.
- A unit of video, each of which may be encoded at multiple different rates, stored in different files.: Chunk
- A file containing the location and encoding rate of files corresponding to video segments in a video.: Manifest
- An approach that allows a client to adapt the encoding rate of retrieved video to network congestion conditions.: DASH
- A CDN approach that stores content in access networks, close to clients.:Enter deep
-
In DASH (Dynamic, Adaptive Streaming over HTTP), a server divides a video file into chunks that ... (pick best completion from below)
... are stored, each encoded at multiple rates (video quality). The client plays the video chunk-by-chunk, with each chunk requested at encoding rate that fits the available bandwidth at the time.
-
Which of the following characteristics below are associated with a UDP socket? Check one or more that apply.
- the application must explicitly specify the IP destination address and port number for each group of bytes written into a socket
- data from different clients can be received on the same socket
- socket(AF_INET, SOCK_DGRAM) creates this type of socket
- provides unreliable transfer of a groups of bytes ("a datagram"), from client to server
-
Which of the following characteristics below are associated with a TCP socket? Check one or more that apply.
- socket(AF_INET, SOCK_STREAM) creates this type of socket
- a server can perform an accept() on this type of socket
- when contacted, the server will create a new server-side socket to communicate with that client
- provides reliable, in-order byte-stream transfer (a "pipe"), from client to server
-
How does the networked application running on a server know the client IP address and the port number to reply to in response to a received datagram?
The application code at the server determines client IP address and port # from the initial segment sent by client, and must explicitly specify these values when sending into a socket back to that client.
-
Suppose a Web server has five ongoing connections that use TCP receiver port 80, and assume there are no other TCP connections (open or being opened or closed) at that server. How many TCP sockets are in use at this server?
6
-
What happens when a socket connect() procedure is called/invoked?
This procedure creates a new socket at the client, and connects that socket to the specified server.
-
Where is transport-layer functionality primarily implemented?
Transport layer functions are implemented primarily at the hosts at the "edge" of the network.
-
True or False: The transport layer provides for host-to-host delivery service?
True.
-
Check all of the services below that are provided by the TCP protocol.
- A flow-control service that ensures that a sender will not send at such a high rate so as to overflow receiving host buffers.
- In-order data delivery
- Reliable data delivery.
- A byte stream abstraction, that does not preserve boundaries between message data sent in different socket send calls at the sender.
- A congestion control service to ensure that multiple senders do not overload network links.
-
Check all of the services below that are provided by the UDP protocol.
A message abstraction, that preserves boundaries between message data sent in different socket send calls at the sender.
-
The transport layer sits on top of the network layer, and provides its services using the services provided to it by the network layer. Thus it’s important that we know what is meant by the network layer’s “best effort” delivery service. True or False:
The network layer’s best-effort delivery service means that IP makes its “best effort” to deliver segments between communicating hosts, but it makes no guarantees. In particular, it does not guarantee segment delivery, it does not guarantee orderly delivery of segments, and it does not guarantee the integrity of the data in the segments.
Correct! The network layer's best effort service doesn't really provide much service at all, does it?
-
What is meant by transport-layer demultiplexing?
Receiving a transport-layer segment from the network layer, extracting the payload (data) and delivering the data to the correct socket.
-
What is meant by transport-layer multiplexing?
Taking data from one socket (one of possibly many sockets), encapsulating a data chuck with header information - thereby creating a transport layer segment - and eventually passing this segment to the network layer.
-
True or False: When multiple UDP clients send UDP segments to the same destination port number at a receiving host, those segments (from different senders) will always be directed to the same socket at the receiving host.
True
-
True or False: When multiple TCP clients send TCP segments to the same destination port number at a receiving host, those segments (from different senders) will always be directed to the same socket at the receiving host.
False
-
True or False: It is possible for two UDP segments to be sent from the same socket with source port 5723 at a server to two different clients.
True
-
True or False: It is possible for two TCP segments with source port 80 to be sent by the sending host to different clients.
True
-
True or False: On the sending side, the UDP sender will take each application-layer chunk of data written into a UDP socket and send it in a distinct UDP datagram. And then on the receiving side, UDP will deliver a segment's payload into the appropriate socket, preserving the application-defined message boundary.
True
-
Which of the fields below are in a UDP segment header? [Hint: note the use of the word "header" in this question statement.]
- Source port number
- Length (of UDP header plus payload)
- Internet checksum
- Destination port number
-
Why is the UDP header length field needed?
Because the payload section can be of variable length, and this lets UDP know where the segment ends.
-
Over what set of bytes is the checksum field in the UDP header computed over?
The entire UDP segment, except the checksum field itself, and the IP sender and receive address fields
-
Which of the following statements are true about a checksum? Hint: more than one statement is true.
- The receiver of a packet with a checksum field will add up the received bytes, just as the sender did, and compare this locally-computed checksum with the checksum value in the packet header. If these two values are different then the receiverknows that one of the bits in the received packet has been changed during transmission from sender to receiver.
- The sender-computed checksum value is often included in a checksum field within a packet header.
- A checksum is computed at a sender by considering each byte within a packet as a number, and then adding these numbers (each number representing a bytes) together to compute a sum (which is known as a checksum).
-
Compute the Internet checksum value for these two 16-bit words: 11110101 11010011 and 10110011 01000100
01010110 11100111
-
Compute the Internet checksum value for these two 16-bit words: 01000001 11000100 and 00100000 00101011
10011110 00010000
-
True or False: When computing the Internet checksum for two numbers, a single flipped bit (i.e., in just one of the two numbers) will always result in a changed checksum.
True
-
True or False: When computing the Internet checksum for two numbers, a single flipped bit in each of the two numbers will always result in a changed checksum.
False
-
Suppose a UDP segment (A in the figure below) arrives at a host with an IP address of 128.119.40.186. The source port in the UDP segment is 4829 and the destination port is 3546. The IP address of the sending host is 60.54.75.24.
Now consider the UDP datagram (and the IP datagram that will encapsulate it) sent in reply by the application on host 128.119.40.186 to the original sender host, labeled B in the figure above. Complete the sentences below ...
What are the source and destination port numbers and IP addresses? (Enter the integer port number or the 4-part dotted decimal IP address, included the period)
QUESTION LIST:
-
The source port number of the UDP segment (B) sent in reply is: 3546
-
The source IP address of the IP datagram containing the UDP segment (B) sent in reply is: 128.119.40.186
-
The destination port number of the UDP segment (B) sent in reply is: 4829
-
The destination IP address of the IP datagram containing the UDP segment (B) sent in reply is: 60.54.75.24
-
-
Consider the purposes/goals/use of different reliable data transfer protocol mechanisms. For the given purpose/goal/use match it to the RDT mechanism that is used to implement the given purpose/goal/use.
- Lets the sender know that a packet was NOT received correctly at the receiver. NAK
- Used by sender or receiver to detect bits flipped during a packet's transmission. Checksum
- Allows for duplicate detection at receiver. Sequence numbers
- Lets the sender know that a packet was received correctly at the receiver. ACK
- Allows the receiver to eventually receive a packet that was corrupted or lost in an earlier transmission. Retransmission
-
Consider the rdt 2.0 sender and receiver shown below, with FSM transitions at the sender labeled S1, S2, and S3; and receiver transitions labeled R1 and R2.
Which of the following sequences of transitions could possibly occur as a result of an initial rdt_send() call at the sender, and possible later message corruption and subsequent error recovery.
- S1, R2, S3
- S1, R1, S2
- S1, R1, S2, R2, S3
-
Consider the rdt2.1 sender and receiver FSMs shown below, with labeled transitions S1 through S6 at the sender, and transitions R1 through R6 at the receiver. The sender and receiver start in the “Wait for call 0 from above” and “Wait for 0 from below” states, respectively.
Suppose that no channel errors occur. A sequence of interleaved sender and receiver transitions is given below. Transitions S1 and S4 are already provided. Choose the sender or receiver transition for the unlabeled transitions x1, x2, x3, and x4 below to indicate the time-ordered sequence of transitions (interleaved sender and receiver transitions) that will result in two messages being delivered at the receiver, with the sender and receiver returning to their initial states (again, given that no channel errors occur).
S1, x1, x2, S4, x3, x4
QUESTION LIST:
-
transition x1 R1
-
transition x2 S3
-
transition x3 R4
-
transition x4 S6
-
-
Consider the rdt2.1 sender and receiver FSMs shown below, with labeled transitions S1 through S6 at the sender, and transitions R1 through R6 at the receiver. The sender and receiver start in the “Wait for call 0 from above” and “Wait for 0 from below” states, respectively.
Suppose that the initial message transmission by the sender is corrupted, but that no other message transmissions are corrupted. Match the unlabeled transitions x1, x2, x3, x4, x5 in the time-ordered sequence of transitions below (interleaved sender and receiver transitions) that will occur following the initial S1 transition (which is corrupted), that will result in two messages being delivered at the receiver, with the sender and receiver returning to their initial states (again, given that the initial message transmission by the sender is corrupted). Note that transitions S1, S4, and S6 are already provided below.
S1 (message corrupted), x1, x2, x3, x4, S4, x5, S6.
-
transition x1 R6
-
transition x2 S2
-
transition x3 R1
-
transition x4 S3
-
transition x5 R4
-
-
Consider the rdt2.1 sender and receiver FSMs shown below, with labeled transitions S1 through S6 at the sender, and transitions R1 through R6 at the receiver. The sender and receiver start in the “Wait for call 0 from above” and “Wait for 0 from below” states, respectively.
Suppose that the first packet from the sender is correctly received at the receiver but that ACK message sent from receiver-to-sender is corrupted; all other messages (before or after that ACK) are transmitted error-free. Match the unlabeled transitions x1, x2, x3, x4, x5 in the time-ordered sequence of transitions below (interleaved sender and receiver transitions) that will occur following the initial S1 transition, which is followed by a corrupted ACK transmission, that will result in a message being delivered at the receiver, with the sender and receiver returning to their initial states. Note that some transitions are already provided below.
S1, x1 (ACK corrupted), x2, x3, x4, S4, x5, S6.
-
transition x1 R1 (ACK corrupted)
-
transition x2 S2
-
transition x3 R3
-
transition x4 S3
-
transition x5 R4
-
-
What is meant by a cumulative acknowledgment, ACK*(n)*?
A cumulative ACK*(n)* acks all packets with a sequence number up to and including n as being received.
-
Suppose a packet is 10K bits long, the channel transmission rate connecting a sender and receiver is 10 Mbps, and the round-trip propagation delay is 10 ms. What is the maximum channel utilization of a stop-and-wait protocol for this channel?
.1
-
Suppose a packet is 10K bits long, the channel transmission rate connecting a sender and receiver is 10 Mbps, and the round-trip propagation delay is 10 ms. What is the channel utilization of a pipelined protocol with an arbitrarily high level of pipelining for this channel?
1.0
-
Suppose a packet is 10K bits long, the channel transmission rate connecting a sender and receiver is 10 Mbps, and the round-trip propagation delay is 10 ms. How many packets can the sender transmit before it starts receiving acknowledgments back?
10
-
Which of the following statements about pipelining are true? One or more statements may be true.
- With a pipelined sender, there may be transmitted packets "in flight" - propagating through the channel - packets that the sender has sent but that the receiver has not yet received.
- A pipelined sender can have transmitted multiple packets for which the sender has yet to receive an ACK from the receiver.
-
What are some reasons for discarding received-but- out-of-sequence packets at the receiver in GBN? Indicate one or more of the following statements that are correct.
- The sender will resend that packet in any case.
- The implementation at the receiver is simpler
-
What are some reasons for not discarding received-but- out-of-sequence packets at the receiver in GBN? Indicate one or more of the following statements that are correct.
Even though that packet will be retransmitted, its next retransmission could be corrupted, so don't discard a perfectly well-received packet, silly!
-
In the SR receiver window (see diagram below, taken from PPT slides and video), why haven't the red packets been delivered yet? Check the one or more reasons below that apply.
There is a packet with a lower sequence number than any of the red packets that has yet to be received, so in-order delivery of data in the red packets up to the application layer is not possible
-
In SR, why does the receiver have to acknowledge packets with sequence numbers that are less than (and to the left of) those in its window, which starts at rcv_base.
Because the sender may not have received an ACK for that packet yet.
-
True or False: On the sending side, the TCP sender will take each application-layer chunk of data written into a TCP socket and send it in a distinct TCP segment. And then on the receiving side, TCP will deliver a segment's payload into the appropriate socket, preserving the application-defined message boundary.
False
-
Consider the TCP Telnet scenario below (from Fig. 3.31 in text). Why is it that the receiver sends an ACK that is one larger than the sequence number in the received datagram?
Because the send-to receiver segment carries only one byte of data, and after that segment is received, the next expected byte of data is just the next byte (i.e., has an index that is one larger) in the data stream.
-
Consider TCP use of an exponentially weighted moving average (EWMA) to compute the nth value of the estimated RTT:
EstimatedRTTn = (1- a)EstimatedRTTn-1 + aSampleRTTn
True or False: with this EWMA algorithm the value of EstimatedRTTn has no dependence on the earlier sample, SampleRTTn-1
False
-
Consider the TCP Telnet scenario below (from Fig. 3.36 in text). What timer-related action does the sender take on the receipt of ACK 120?
Cancels any running timers.
-
True or False: with TCP's flow control mechanism, where the receiver tells the sender how much free buffer space it has (and the sender always limits the amount of outstanding, unACKed, in-flight data to less than this amount), it is not possible for the sender to send more data than the receiver has room to buffer.
True
-
Consider TCP’s Fast Retransmit optimization (see Figure 3.37 from the text, below). Of course, the sender doesn't know for sure that the segment with sequence # 100 is actually lost (it can’t see into the channel). Can a sender get three duplicate ACKs for a segment that in fact has not been lost? Which of the following statements are true? Suppose a channel can lose, but will not corrupt, messages.
If the channel can reorder messages, a triple duplicate ACK can occur even though a message is not lost; since it's possible that a message has just been reordered and has not yet arrived when the three duplicate ACKs were generated.
If the channel cannot reorder messages, a triple duplicate ACK indicates to the sender that a segment loss has happened for sure. Actually (again assuming the channel cannot corrupt or reorder messages), even a single duplicate ACK would indicate that a segment loss has happed for sure.
-
Match the description of a TCP connection management message with the name of the message used to accomplish that function.
- A message from client to server initiating a connection request. SYN message
- A message from server to client ACKing receipt of a SYN message and indicating the willingness of the server to establish a TCP connection with the client. SYNACK message
- A message indicating that the sending side is initiating the protocol to terminate a connection. FIN message
- A message sent in response to a request to terminate a connection, ACKing that the side receiving this message is also willing to terminate the connection FINACK message
- A general purpose error message used during connection set up or tear down to let the other side know that an error has occurred, and that the referenced connection should be shut down. RESET message
-
For the given function of a field in the TCP segment, select the name of that field from the pull-down list.
- This field contains the port number associated with the sending socket for this TCP segment. Souce Port Number
- this field contains application data that was written into a socket by the sender of this TCP segment. Data (or payload)
- This field contains the index in the sender-to-receiver byte stream of the first byte of that data in the payload carried in this segment. Sequence number
- This field contains the index in the byte stream of the next in-order byte expected at the receiver ACK number field
- If set, this segment cumulatively ACKs all data bytes up to, but not including, the byte index in the ACK value field of this segment. ACK bit
- This field contains the number of available bytes in the TCP receiver's buffer. Receiver advertised window
- This field contains the Internet checksum of the TCP segment and selected fields in the IP datagram header. Checksum
- This field contains the number of bytes in the TCP header. Header length field
-
Suppose that as shown in the figure below, a TCP sender is sending segments with 100 bytes of payload. The TCP sender sends five segments with sequence numbers 100, 200, 300, 400, and 500. Suppose that the segment with sequence number 300 is lost. The TCP receiver will buffer correctly-received but not-yet-in-order segments for later delivery to the application layer (once missing segments are later received).
-
After receiving segment 100, the receiver responds with an ACK with value: 200
-
After receiving segment 200, the receiver responds with an ACK with value: 300
-
After receiving segment 500, the receiver responds with an ACK with value: 300, duplicate ack
-
After receiving the retransmitted segment 300, the receiver responds with an ACK with value: 600
-
The TCP receiver does not respond in the example, with an ACK with value: 400
-
-
Consider the five images below. Indicate which of these images suggest the need for flow control (the others would suggest the need for congestion control).
- A talking head
- A glass overflowing
-
Consider the figure below, which shows the application-to-application throughput achieved when two senders are competing at a shared bottleneck link. Suppose that when the overall arrival rate, lambdain' (for each sender) is close to R/2, the throughput to the application layer (at each receiver), lambdaout, is equal to 0.8 * lambdain'.What fraction of the packets transmitted at the sender are retransmissions?
.20
-
Which of the following actions are used in network-assisted congestion control (say versus end-end congestion control) to signal congestion. Check all that apply.
- A router marks a field in the datagram header at a congested router.
- A router sends an ICMP message to a host telling it to slow down its sending rate.
-
Which of the following actions are associated with end-end congestion control (say versus network-assisted congestion control). Check all that apply.
- A datagram experiences delay at a congested network router, which is then measured by the sender and used to decrease the sending rate.
- A sender decreases its sending rate in response to packet loss detected via its transport-layer ACKing.
- The transport-layer sender decreases its sending rate in response to a measured increase in the RTT.
- A router drops a packet at a congested router, which causes the transport-layer sender to infer that there is congestion due to the missing ACK for the lost packet.
-
Use the pulldown menu to match a congestion control approach to how the sender detects congestion.
- The sender infers segment loss from the absence of an ACK from the receiver end-end
- Bits are set at a congested router in a sender-to-receiver datagram, and bits are in the returned to the sender in a receiver-to sender ACK, to indicate congestion to the sender. network-assisted
- The sender measures RTTs and uses the current RTT measurement to infer the level of congestion.. delay-based
-
Which of the following statements about TCP's Additive-increase-multiplicative-decrease (AIMD) algorithm are true? Check all that are true.
- AIMD cuts the congestion window size, cwnd, in half whenever loss is detected by a triple duplicate ACK.
- AIMD is a end-end approach to congestion control.
- AIMD cuts the congestion window size,cwnd, i to 1 whenever a timeout occurs.
-
How is the sending rate typically regulated in a TCP implementation?
By keeping a window of size cwnd over the sequence number space, and making sure that no more than cwnd bytes of data are outstanding (i.e, unACKnowledged). The size of cwnd is regulated by AIMD.
-
Which of the following best completes this sentence: "In the absence of loss, TCP slow start increases the sending rate ... "
" ... faster than AIMD. In fact, slowstart increases the sending rate exponentially fast per RTT."
-
Consider the transport-layer flows interacting at a congested link. In the face of such congestion, what happens at this link to a transport-layer flow that does not cut back on its sending rate?
Nothing different from the other flows crossing the congested link.
-
Assuming that the congestion window size,cwnd, has not yet reached Wmax, TCP CUBIC will ... (check all that apply)
- ... always have a window size, cwnd, and hence a sending rate, higher than that of AIMD (assuming a given window size, Wmax, at which loss would occur)
- .... increase its sending rate faster than AIMD when cwnd is far away from Wmax, but increase slower than AIMD when cwnd is closer to Wmax
-
For delay-based congestion control, match the sender action to the relationship of the currently measured throughput to the value of cwnd/RTTmin
- The currently measured throughput is greater than cwnd/RTTmin. This should never happen
- The currently measured throughput is equal to or a bit less than than cwnd/RTTmin. increase the sending rate
- The currently measured throughput is much less that than cwnd/RTTmin. decrease the sending rate
-
What are advantages of the streams concept in QUIC? Select all that apply.
Since each stream has its own error control, if one stream experiences an error (e.g., lost or damaged segment), the other streams are unaffected.Streams allow concurrent retrieval of web objects, while avoiding Head of the Line (HOL) blocking.
-
What are advantages of implementing transport-layer functionality in QUIC at the application layer? Select all that apply.
QUIC can establish all connection parameters (security, reliability, flow and congestion control)in just one handshake rather than separately in two.As an application-layer protocol, QUIC can be updated/modified at "app frequency" rather than at the frequency of operating system updates.
- Check all of the statements below about where (in the network) the network layer is implemented that are true.
- The network layer is implemented in routers in the network core.
- The network layer is implemented in hosts at the network's edge.
- Consider the travel analogy discussed in the textbook - some actions we take on a trip correspond to forwarding and other actions we take on a trip correspond to routing. Which of the following travel actions below correspond to forwarding? The other travel actions that you don't select below then correspond to routing.
- A car stops at an intersection to "gas-up" and take a "bathroom break"
- A car takes the 3rd exit from a roundabout.
- A car waits at light and then turns left at the intersection.
- For each of the actions below, select those actions below that are primarily in the network-layer data plane. The other actions that you don't select below then correspond to control-plane actions.
- Moving an arriving datagram from a router’s input port to output port
- Looking up address bits in an arriving datagram header in the forwarding table.
- Dropping a datagram due to a congested (full) output buffer.
- We've seen that there are two approaches towards implementing the network control plane - a per-router control-plane approach and a software-defined networking (SDN) control-plane approach. Which of the following actions occur in a per-router control-plane approach? The other actions that you don't select below then correspond to actions in an SDN control plane.
- A router exchanges messages with another router, indicating the cost for it (the sending router) to reach a destination host.
- Routers send information about their incoming and outgoing links to other routers in the network.
- Which of the following quality-of-service guarantees are part of the Internet’s best-effort service model? Check all that apply.
- None of the other services listed here are part of the best-effort service model. Evidently, best-effort service really means no guarantees at all!
-
Match the names of the principal router components (A,B,C,D below) with their function and whether they are in the network-layer data plane or control plane.
- A. input ports, operating primarily in the data plane.
- B. the switching fabric, operating primarily in the data plane.
- C. output ports, operating primarily in the data plane.
- D. the routing processor, operating primarily in the control plane.
-
Where in a router is the destination IP address looked up in a forwarding table to determine the appropriate output port to which the datagram should be directed?
- At the input port where a packet arrives.
-
Where in a router does "match plus action" happen to determine the appropriate output port to which the arriving datagram should be directed?
- At the input port where a packet arrives.
-
Suppose a datagram is switched through the switching fabric and arrives to its appropriate output to find that there are no free buffers. In this case:
- The packet will either be dropped or another packet will be removed (lost) from the buffer to make room for this packet, depending on policy. But the packet will definitely not be be sent back to the input port.
-
What is meant by Head of the Line (HOL) blocking?
- A queued datagram waiting for service at the front of a queue prevents other datagrams in queue from moving forward in the queue.
-
What are the principal components of the IPv4 protocol (check all that apply)?
- IPv4 datagram format.
- Packet handling conventions at routers (e.g., segmentation/reassembly)
- IPv4 addressing conventions.
-
IPv4 Header
- Version field = contains the IP protocol version number
- Type-of-service field = contains Explicit Congestion Notification (ECN) and differentiated service bits
- Fragmentation offset field = used for datagram fragmentation/reassembly
- Time-to-live field = value in this field is decremented at each router; when it reaches zero, the packet must be dropped (this prevents datagrams from looping forever in the network)
- Header checksum field = contains the Internet checksum of this datagram's header fields
- Upper layer field = contains the "protocol number" for the transport-layer protocol to which the datagram's payload will be multiplexed - UDP or TCP, for example
- Payload/data field = contains a UDP or TCP segment
- Datagram length field = indicates the total number of bytes in datagram
-
Which of the following statements is true regarding an IP address? (Zero, one or more of the following statements is true).
- An IP address is associated with an interface.
- If a host has more than one interface, then it has more that one IP address at which it can be reached.
- If a router has more than one interface, then it has more that one IP address at which it can be reached.
-
What is meant by an IP subnet? (Check zero, one or more of the following characteristics of an IP subnet).
- A set of device interfaces that can physically reach each other without passing through an intervening router.
- A set of devices that have a common set of leading high order bits in their IP address.
-
Consider the three subnets in the diagram below.
- What is the maximum # of interfaces in the 223.1.2/24 network?
- 256
- What is the maximum # of interfaces in the 223.1.3/29 network?
- 8
- Which of the following addresses can not be used by an interface in the 223.1.3/29 network? Check all that apply.
- 223.1.2.6
- 223.1.3.28
- 223.1.3.16
- What is the maximum # of interfaces in the 223.1.2/24 network?
-
What is meant by saying that DHCP is a "plug and play" protocol?
- No manual configuration is needed for the host to join the network.
-
Which of the following statements about a DHCP request message are true (check all that are true). Hint: check out Figure 4.24 in the 7th and 8th edition of our textbook.
- A DHCP request message is sent broadcast, using the 255.255.255.255 IP destination address.
- The transaction ID in a DHCP request message will be used to associate this message with future DHCP messages sent from, or to, this client.
- A DHCP request message may contain the IP address that the client will use
-
Which of the following fields occur ONLY in the IPv6 datagram header (i.e., appear in the IPv6 header but not in the IPv4 header)? Check all that apply.
- 128-bit source and destination IP addresses.
- The flow label field.
-
What is the purpose of the Dynamic Host Configuration Protocol?
- To obtain an IP address for a host attaching to an IP network.
-
Destination-based forwarding, which we studied in section 4.2, is a specific instance of match+action and generalized forwarding. Select the phrase below which best completes the following sentence: "In destination-based forwarding, ..."
- ... after matching on the destination IP address in the datagram header, the action taken is to forward the datagram to the output port associated with that destination IP address.
-
Which of the following match+actions can be taken in the generalized OpenFlow 1.0 match+action paradigm that we studied in Section 4.4? Check all that apply.
- ... after matching on the destination IP address in the datagram header, the action taken is to decide whether or not to drop that datagram.
- ... after matching on the destination IP address in the datagram header, the action taken is to forward the datagram to the output port associated with that destination IP address.
- ... after matching on the source and destination IP address in the datagram header, the action taken is to forward the datagram to the output port associated with that source and destination IP address pair.
- ... after matching on the 48-bit link-layer destination MAC address, the action taken is to forward the datagram to the output port associated with that link-layer address.
- ... after matching on the port number in the segment's header, the action taken is to decide whether or not to drop that datagram containing that segment.
- ... after matching on the port number in the segment's header, the action taken is to forward the datagram to the output port associated with that destination IP address.
-
Which of the following fields in the frame/datagram/segment/application-layer message can be matched in OpenFlow 1.0? Check all that apply.
- Source and/or destination port number
- Upper layer protocol field
- IP type-of-service field
- IP destination address
- IP source address
-
Consider the figure below that shows the generalized forwarding table in a router. Recall that a * represents a wildcard value. Now consider an arriving datagram with the IP source and destination address fields indicated below. For each source/destination IP address pair, indicate which rule is matched. Note: assume that a rule that is earlier in the table takes priority over a rule that is later in the table and that a datagram that matches none of the table entries is dropped.
- _____ Source: 1.2.56.32 Destination:128.116.40.186 = Rule 2, with action drop
- _____ Source: 65.92.15.27 Destination: 3.4.65.76 = Rule 1, with action forward(2)
- _____ Source: 10.1.2.3 Destination: 7.8.9.2 = Rule 3, with action send to controller
- _____ Source: 10.1.34.56 Destination: 54.72.29.90 = No match to any rule.
-
Consider the network below. We want to specify the match+action rules at s3 so that only the following network-wide behavior is allowed:
- traffic from 128.119/16 and destined to 137.220/16 is forwarded on the direct link from s3 to s1;
- traffic from 128.119/16 and destined to 67.56/16 is forwarded on the direct link from s3 to s2;
- incoming traffic via port 2 or 3, and destined to 128.119/16 is forwarded to 128.119/16 via local port 1.
- No other forwarding should be allowed. In particular s3 should not forward traffic arriving from 137.220/16 and destined for 67.56/16 and vice versa.
From the list of match+action rules below, select the rules to include in s3's flow table to implement this forwarding behavior. Assume that if a packet arrives and finds no matching rule, it is dropped.
- Input port: 2; Dest: 128.119/16 Action: forward(1)
- Input port:1 ; Dest: 137.220/16 Action: forward(2)
- Input port: 3; Dest: 128.119/16 Action: forward(1)
- Input port: 1; Dest: 67.56/16 Action: forward(3)
-
Consider the network below. We want to specify the match+action rules at s3 so that s3 acts only as a relay for traffic between 137.220/16 and 67.56/16. In particular s3 should not accept/forward and traffic to/from 128.119/16.
From the list of match+action rules below, select the rules to include in s3's flow table to implement this forwarding behavior. Assume that if a packet arrives and finds no matching rule, it is dropped.
- Input port: 2; Dest: 67.56/16 Action: forward(3)
- Input port: 3; Dest: 137.220/16 Action: forward(2)
-
What is meant by generalized forwarding (as opposed to destination-based forwarding) in a router or switch?
- Any of several actions (including drop (block), forward to a given interface, or duplicate-and-forward) can be made based on the contents of one or more packet header fields.
- Which of the following network devices can be thought of as a "middlebox"? Check all that apply.
- HTTP load balancer
- HTTP cache
- Network Address Translation box
- What protocol (or protocols) constitutes the "thin waist" of the Internet protocol stack? Check all that apply.
- IP
- Which of the statements below are true statements regarding the "end-to-end principle"? Check all that apply.
- The end-to-end argument advocates placing functionality at the network edge because some functionality cannot be completely and correctly implemented in the network, and so needs to be placed at the edge in any case, making in-network implementation redundant.
- The end-to-end argument allows that some redundant functionality might be placed both in-network and at the network edge in order to enhance performance.
- What is meant when it is said that the Internet has an “hourglass” architecture? See the picture below if you are unfamiliar with an "hourglass".
- The Internet protocol stack has a “thin waist” in the middle, like an hourglass. The Internet Protocol (IP) is the only network-layer protocol in the middle layer of the stack. Every other layer has multiple protocols at that layer.
- In the US, which of the following services has been regulated by the Federal Communications Commission (FCC) going back into the 20th century?
- Telecommunication services.
Consider the circuit-switched network shown in the figure below, with circuit switches A, B, C, and D. Suppose there are 12 circuits between A and B, 14 circuits between B and C, 18 circuits between C and D, and 11 circuits between D and A.
-
What is the maximum number of connections that can be ongoing in the network at any one time?
-
Suppose that these maximum number of connections are all ongoing. What happens when another call connection request arrives to the network, will it be accepted? Answer Yes or No
-
Suppose that every connection requires 2 consecutive hops, and calls are connected clockwise. For example, a connection can go from A to C, from B to D, from C to A, and from D to B. With these constraints, what is the is the maximum number of connections that can be ongoing in the network at any one time?
-
Suppose that 16 connections are needed from A to C, and 12 connections are needed from B to D. Can we route these calls through the four links to accommodate all 28 connections? Answer Yes or No
-
The maximum number of connections that can be ongoing at any one time is the sum of all circuits, which happens when 14 connections go from A to B, 19 connections go from B to C, 18 connections go from C to D, and 10 connections go from D to A. This sum is 61.
-
No, it will be blocked because there are no free circuits.
-
There can be a maximum of 29 connections. Consider routes A->C and C->A, sum the bottleneck links, consider any leftover capacity that would allow for B->D and D->B connections, and compare that value to the equivalent of B->D and D->B.
-
Using our answer from question 4, the sum of our needed connections is 28, and we have 29 available connections, so it is possible.
This question requires a little bit of background in probability (but we'll try to help you though it in the solutions). Consider the two scenarios below:
- A circuit-switching scenario in which Ncs users, each requiring a bandwidth of 25 Mbps, must share a link of capacity 200 Mbps.
- A packet-switching scenario with Nps users sharing a 200 Mbps link, where each user again requires 25 Mbps when transmitting, but only needs to transmit 10 percent of the time.
-
When circuit switching is used, what is the maximum number of users that can be supported?
-
Suppose packet switching is used. If there are 15 packet-switching users, can this many users be supported under circuit-switching? Yes or No.
-
Suppose packet switching is used. What is the probability that a given (specific) user is transmitting, and the remaining users are not transmitting?
-
Suppose packet switching is used. What is the probability that one user (any one among the 15 users) is transmitting, and the remaining users are not transmitting?
-
When one user is transmitting, what fraction of the link capacity will be used by this user? Write your answer as a decimal.
-
What is the probability that any 6 users (of the total 15 users) are transmitting and the remaining users are not transmitting?
-
What is the probability that more than 8 users are transmitting?
-
When circuit switching is used, at most 8 users can be supported. This is because each circuit-switched user must be allocated its 25 Mbps bandwidth, and there is 200 Mbps of link capacity that can be allocated.
-
No. Under circuit switching, the 15 users would each need to be allocated 25 Mbps, for an aggregate of 375 Mbps - more than the 200 Mbps of link capacity available.
-
The probability that a given (specific) user is busy transmitting, which we'll denote p, is just the fraction of time it is transmitting, i.e. 0.1. The probability that one specific other user is not busy is (1-p), and so the probability that all of the other Nps-1 users are not transmitting is (1-p)Nps-1. Thus the probability that one specific user is transmitting and the remaining users are not transmitting is p*(1-p)Nps-1, which has the numerical value of 0.023.
-
The probability that exactly one (any one) of the Nps users is transmitting is Nps times the probability that a given specific user is transmitting and the remaining users are not transmitting. The answer is thus Nps * p * (1-p)Nps-1, which has the numerical value of 0.34.
-
This user will be transmitting at a rate of 25 Mbps over the 200 Mbps link, using a fraction 0.13 of the link's capacity when busy.
-
The probability that 6 specific users of the total 15 users are transmitting and the other 9 users are idle is p6(1-p)9. Thus the probability that any 4 of the 7 users are busy is choose(15, 6) * p6(1-p)9, where choose(15, 6) is the (15, 6) coefficient of the binomial distribution). The numerical value of this probability is 0.0019.
-
The probability that more than 8 users of the total 15 users are transmitting is Σ i=9,15 choose(15, i) * pi(1-p)15 - i. The numerical value of this probability is 2.85E-6. Note that 8 is the maximum number of users that can be supported using circuit switching. With packet switching, nearly twice as many users (15) are supported with a small probability that more than 8 of these packet-switching users are busy at the same time.
Consider the figure below, adapted from Figure 1.17 in the text, which draws the analogy between store-and-forward link transmission and propagation of bits in packet along a link, and cars in a caravan being serviced at a toll booth and then driving along a road to the next tollbooth.
Suppose the caravan has 10 cars, and that the tollbooth services (that is, transmits) a car at a rate of one car per 1 seconds. Once receiving serving a car proceeds to the next tool both, which is 200 kilometers away at a rate of 10 kilometers per second. Also assume that whenever the first car of the caravan arrives at a tollbooth, it must wait at the entrance to the tollbooth until all of the other cars in its caravan have arrived, and lined up behind it before being serviced at the toll booth. (That is, the entire caravan must be stored at the tollbooth before the first car in the caravan can pay its toll and begin driving towards the next tollbooth).
-
Once a car enters service at the tollbooth, how long does it take until it leaves service?
-
How long does it take for the entire caravan to receive service at the tollbooth (that is the time from when the first car enters service until the last car leaves the tollbooth)?
-
Once the first car leaves the tollbooth, how long does it take until it arrives at the next tollbooth?
-
Once the last car leaves the tollbooth, how long does it take until it arrives at the next tollbooth?
-
Once the first car leaves the tollbooth, how long does it take until it enters service at the next tollbooth?
-
Are there ever two cars in service at the same time, one at the first toll booth and one at the second toll booth? Answer Yes or No
-
Are there ever zero cars in service at the same time, i.e., the caravan of cars has finished at the first toll both but not yet arrived at the second tollbooth? Answer Yes or No
-
Service time is 1 seconds
-
It takes 10 seconds to service every car, (10 cars * 1 seconds per car)
-
It takes 20 seconds to travel to the next toll booth (200 km / 10 km/s)
-
Just like in the previous question, it takes 20 seconds, regardless of the car
-
It takes 29 seconds until the first car gets serviced at the next toll booth (10-1 cars * 1 seconds per car + 200 km / 10 km/s)
-
No, because cars can't get service at the next tollbooth until all cars have arrived
-
Yes, one notable example is when the last car in the caravan is serviced but is still travelling to the next toll booth; all other cars have to wait until it arrives, thus no cars are being serviced
Consider the figure below, in which a single router is transmitting packets, each of length L bits, over a single link with transmission rate R Mbps to another router at the other end of the link.
Suppose that the packet length is L= 12000 bits, and that the link transmission rate along the link to router on the right is R = 100 Mbps.
-
What is the transmission delay?
-
What is the maximum number of packets per second that can be transmitted by this link?
The transmission delay = L/R = 12000 bits / 100000000 bps = 0.00012 seconds
The number of packets that can be transmitted in a second into the link = R / L = 100000000 bps / 12000 bits = 8333 packets
Consider the queuing delay in a router buffer, where the packet experiences a delay as it waits to be transmitted onto the link. The length of the queuing delay of a specific packet will depend on the number of earlier-arriving packets that are queued and waiting for transmission onto the link. If the queue is empty and no other packet is currently being transmitted, then our packet’s queuing delay will be zero. On the other hand, if the traffic is heavy and many other packets are also waiting to be transmitted, the queuing delay will be long.
Assume a constant transmission rate of R = 400000 bps, a constant packet-length L = 3900 bits, and a is the average rate of packets/second. Traffic intensity I = La/R, and the queuing delay is calculated as I(L/R)(1 - I) for I < 1.
-
In practice, does the queuing delay tend to vary a lot? Answer with Yes or No
-
Assuming that a = 33, what is the queuing delay? Give your answer in milliseconds (ms)
-
Assuming that a = 63, what is the queuing delay? Give your answer in milliseconds (ms)
-
Assuming the router's buffer is infinite, the queuing delay is 2.3101 ms, and 1819 packets arrive. How many packets will be in the buffer 1 second later?
-
If the buffer has a maximum size of 968 packets, how many of the 1819 packets would be dropped upon arrival from the previous question?
-
Yes, in practice, queuing delay can vary significantly. We use the above formulas as a way to give a rough estimate, but in a real-life scenario it is much more complicated.
-
Queuing Delay = I(L/R)(1 - I) * 1000 = 0.3218*(3900/400000)*(1-0.3218) * 1000 = 2.1279 ms.
-
Queuing Delay = I(L/R)(1 - I) * 1000 = 0.6143*(3900/400000)*(1-0.6143) * 1000 = 2.3101 ms.
-
Packets left in buffer = a - floor(1000/delay) = 1819 - floor(1000/2.3101) = 1387 packets.
-
Packets dropped = packets - buffer size = 1819 - 968 = 851 dropped packets.
Consider the figure below, with three links, each with the specified transmission rate and link length.
Assume the length of a packet is 4000 bits. The speed of light propagation delay on each link is 3x10^8 m/sec
-
What is the transmission delay of link 1?
-
What is the propogation delay of link 1?
-
What is the total delay of link 1?
-
What is the transmission delay of link 2?
-
What is the propogation delay of link 2?
-
What is the total delay of link 2?
-
What is the transmission delay of link 3?
-
What is the propogation delay of link 3?
-
What is the total delay of link 3?
-
What is the total delay?
Link 1 transmission delay = L/R = 4000 bits / 1000 Mbps = 4.00E-6 seconds
Link 1 propagation delay = d/s = ()3 Km) * 1000 / 3*10^8 m/sec = 1.00E-5 seconds
Link 1 total delay = d_t + d_p = 4.00E-6 seconds + 1.00E-5 seconds = 1.40E-5 seconds
Link 2 transmission delay = L/R = 4000 bits / 10 Mbps = 0.0004 seconds
Link 2 propagation delay = d/s = ()5000 Km) * 1000 / 3*10^8 m/sec = 0.017 seconds
Link 2 total delay = d_t + d_p = 0.0004 seconds + 0.017 seconds = 0.017 seconds
Link 3 transmission delay = L/R = 4000 bits / 10 Mbps = 0.0004 seconds
Link 3 propagation delay = d/s = ()1 Km) * 1000 / 3*10^8 m/sec = 3.33E-6 seconds
Link 3 total delay = d_t + d_p = 0.0004 seconds + 3.33E-6 seconds = 0.0004 seconds
The total delay = d_L1 + d_L2 + d_L3 = 1.40E-5 seconds + 0.017 seconds + 0.0004 seconds = 0.017 seconds
Consider the scenario shown below, with four different servers connected to four different clients over four three-hop paths. The four pairs share a common middle hop with a transmission capacity of R = 400 Mbps. The four links from the servers to the shared link have a transmission capacity of RS = 60 Mbps. Each of the four links from the shared middle link to a client has a transmission capacity of RC = 20 Mbps.
-
What is the maximum achievable end-end throughput (in Mbps) for each of four client-to-server pairs, assuming that the middle link is fairly shared (divides its transmission rate equally)?
-
Which link is the bottleneck link? Format as Rc, Rs, or R
-
Assuming that the servers are sending at the maximum rate possible, what are the link utilizations for the server links (RS)? Answer as a decimal
-
Assuming that the servers are sending at the maximum rate possible, what are the link utilizations for the client links (RC)? Answer as a decimal
-
Assuming that the servers are sending at the maximum rate possible, what is the link utilizations for the shared link (R)? Answer as a decimal
-
The maximum achievable end-end throughput is the capacity of the link with the minimum capacity, which is 20 Mbps
-
The bottleneck link is the link with the smallest capacity between RS, RC, and R/4. The bottleneck link is Rc.
-
The server's utilization = Rbottleneck / RS = 20 / 60 = 0.33
-
The client's utilization = Rbottleneck / RC = 20 / 20 = 1
-
The shared link's utilization = Rbottleneck / (R / 4) = 20 / (400 / 4) = 0.2
In the scenario below, imagine that you're sending an http request to another machine somewhere on the network.
-
What layer in the IP stack best corresponds to the phrase: 'handles the delivery of segments from the application layer, may be reliable or unreliable'
-
What layer in the IP stack best corresponds to the phrase: 'handles messages from a variety of network applications'
-
What layer in the IP stack best corresponds to the phrase: 'passes frames from one node to another across some medium'
-
What layer in the IP stack best corresponds to the phrase: 'bits live on the wire'
-
What layer in the IP stack best corresponds to the phrase: 'moves datagrams from the source host to the destination host'
-
What layer corresponds to box 1?
-
What layer corresponds to box 2?
-
What layer corresponds to box 3?
-
What layer corresponds to box 4?
-
What layer corresponds to box 5?
-
What layer corresponds to box 6?
-
What layer corresponds to box 7?
-
What layer corresponds to box 8?
-
What layer corresponds to box 9?
-
What layer corresponds to box 10?
-
What layer corresponds to box 11?
-
What layer corresponds to box 12?
-
What layer corresponds to box 13?
-
What layer corresponds to box 14?
-
What layer corresponds to box 15?
-
The given phrase corresponds to the Transport Layer.
-
The given phrase corresponds to the Application Layer.
-
The given phrase corresponds to the Link Layer.
-
The given phrase corresponds to the Physical Layer.
-
The given phrase corresponds to the Network Layer.
-
Box 1 is the Application Layer.
-
Box 2 is the Transport Layer.
-
Box 3 is the Network Layer.
-
Box 4 is the Link Layer.
-
Box 5 is the Physical Layer.
-
Box 6 is the Physical Layer.
-
Box 7 is the Link Layer.
-
Box 8 is the Physical Layer.
-
Box 9 is the Link Layer.
-
Box 10 is the Network Layer.
-
Box 11 is the Physical Layer.
-
Box 12 is the Link Layer.
-
Box 13 is the Network Layer.
-
Box 14 is the Transport Layer.
-
Box 15 is the Application Layer.
Imagine that you are trying to visit www.enterprise.com, but you don't remember the IP address the web-server is running on.
Assume the following records are on the TLD DNS server:
- (www.enterprise.com, dns.enterprise.com, NS)
- (dns.enterprise.com, 146.54.219.75, A)
Assume the following records are on the enterprise.com DNS server:
- (www.enterprise.com, west5.enterprise.com, CNAME)
- (west5.enterprise.com, 142.81.17.206, A)
- (enterprise.com, mail.enterprise.com, MX)
- (mail.enterprise.com, 247.29.64.33, A)
Assume your local DNS server only has the TLD DNS server cached.
-
What transport protocol(s) does DNS use: TCP, UDP, or Both?
-
What well-known port does DNS use?
-
In the above example, how many unique type of Resource Records (RR) are there at the authoritative enterprise.com DNS server?
-
Can you send multiple DNS questions and get multiple RR answers in one message? Answer with Yes or No
-
To which DNS server does a host send their requests to? Answer with the full name
-
Which type of DNS server holds a company's DNS records? Answer with the full name
-
In the example given in the problem, what is the name of the DNS server for enterprise.com?
-
When you make the request for www.enterprise.com, your local DNS requests the IP on your behalf. When it contacts the TLD server, how many answers (RR) are returned?
-
In the previous question, there were two responses, one was a NS record and the other an A record. What was the content of the A record? Answer with the format: "name, value"
-
Assume that the enterprise.com website is actually hosted on west5.enterprise.com, what type of record is needed for this?
-
Now imagine we are trying to send an email to [email protected], and their mail server has the name mail.enterprise.com. What type of record will contain the name of the enterprise.com domain and the name of its mailserver(s)?
-
In that MX record, what are the contents? Answer with the format: "name, value"
-
Does your local DNS server take advantage of caching similar to web requests? Answer with Yes or No
-
DNS generally uses UDP, but in some cases (such as zone transfer) it will use TCP, so the answer is: Both.
-
DNS uses well-known port 53.
-
There are 4 types of RR's: A, CNAME, NS, and MX.
-
Yes, there can be multiple 'questions' and 'answers' in a single DNS request.
-
The host first contacts the Local DNS server, which acts on behalf of the host.
-
The company's Authoritative DNS server is where their RR are stored.
-
The Authoritative DNS server for www.enterprise.com is dns.enterprise.com
-
There are 2 records returned; a NS record, and an A record for the DNS server.
-
The A record has contents: (dns.enterprise.com, 146.54.219.75)
-
In this case, a CNAME record is needed.
-
An MX record will be returned.
-
The MX record has contents: (enterprise.com, mail.enterprise.com)
-
Yes, DNS servers (especially your Local DNS server) cache records for faster retrieval.
Assume that a user is trying to visit gaia.cs.umass.edu, but his browser doesn't know the IP address of the website. In this example, examine the difference between an iterative and recursive DNS query.
-
Between steps 1 and 2, where does the Local DNS server check first? Answer with 'User', 'DNS Local', 'DNS Root', 'DNS TLD', or 'DNS Authoritative'.
-
Between steps 2 and 3, assuming the root DNS server doesn't have the IP we want, where does the response link? Answer with 'DNS Local', 'DNS Root', 'DNS TLD', or 'DNS Authoritative'.
-
Between steps 4 and 5, assuming the TLD DNS server doesn't have the IP we want, where does the response link? Answer with 'DNS Local', 'DNS Root', 'DNS TLD', or 'DNS Authoritative'.
-
Between steps 6 and 7, the authoritative DNS server responds with the IP we want. What type of DNS record is returned?
-
Which type of query is considered best practice: iterative or recursive?
-
The Local DNS server first checks the DNS Root.
-
The Local DNS server then checks the DNS TLD server.
-
Finally, the Local DNS server checks the DNS Authoritative server.
-
The DNS record received is type A (Type A is hostname:IP)
-
Iterative is considered 'best practice' because it puts less strain on the Root and TLD DNS servers.
-
Between steps 1 and 2, where does the Local DNS server check first? Answer with 'User', 'DNS Local', 'DNS Root', 'DNS TLD', or 'DNS Authoritative'.
-
Between steps 2 and 3, where does the root DNS forward the request to? Answer with 'DNS Local', 'DNS Root', 'DNS TLD', or 'DNS Authoritative'.
-
Between steps 4 and 5, where does the authoritative DNS forward the response to? Answer with 'DNS Local', 'DNS Root', 'DNS TLD', or 'DNS Authoritative'.
-
In steps 6-8, the response is sent back in the reverse direction until it reaches the user. What type of DNS record is returned?
-
Which type of query is considered best practice: Iterative or Recursive?
-
The Local DNS server first checks the DNS Root.
-
The Root DNS server forwards the request to the DNS TLD server.
-
The Authoritative DNS server forwards the response back to the DNS TLD server.
-
The DNS record received is type A (Type A is hostname:IP)
-
Iterative is considered 'best practice' because it puts less strain on the Root and TLD DNS servers.
Before doing this question, you might want to review sections 2.2.1 and 2.2.2 on HTTP (in particular the text surrounding Figure 2.7) and the operation of the DNS (in particular the text surrounding Figure 2.19).
Suppose within your Web browser you click on a link to obtain a Web page. The IP address for the associated URL is not cached in your local host, so a DNS lookup is necessary to obtain the IP address. Suppose that four DNS servers are visited before your host receives the IP address from DNS. The first DNS server visited is the local DNS cache, with an RTT delay of RTT0 = 3 msecs. The second, third and fourth DNS servers contacted have RTTs of 42, 29, and 14 msecs, respectively. Initially, let's suppose that the Web page associated with the link contains exactly one object, consisting of a small amount of HTML text. Suppose the RTT between the local host and the Web server containing the object is RTTHTTP = 93 msecs.
-
Assuming zero transmission time for the HTML object, how much time (in msec) elapses from when the client clicks on the link until the client receives the object?
-
Now suppose the HTML object references 8 very small objects on the same server. Neglecting transmission times, how much time (in msec) elapses from when the client clicks on the link until the base object and all 8 additional objects are received from web server at the client, assuming non-persistent HTTP and no parallel TCP connections?
-
Suppose the HTML object references 8 very small objects on the same server, but assume that the client is configured to support a maximum of 5 parallel TCP connections, with non-persistent HTTP.
-
Suppose the HTML object references 8 very small objects on the same server, but assume that the client is configured to support a maximum of 5 parallel TCP connections, with persistent HTTP.
-
What's the fastest method we've explored: Nonpersistent-serial, Nonpersistent-parallel, or Persistent-parallel?
-
The time from when the Web request is made in the browser until the page is displayed in the browser is: RTT0 + RTT1 + RTT2 + RTT3 + 2RTTHTTP = 3 + 42 + 29 + 14 + 293 = 274 msecs. Note that 2 RTTHTTP are needed to fetch the HTML object - one RTTHTTP to establish the TCP connection, and then one RTTHTTP to perform the HTTP GET/response over that TCP connection.
-
The time from when the Web request is made in the browser until the page is displayed in the browser is: RTT0 + RTT1 + RTT2 + RTT3 + 2RTTHTTP + 28RTTHTTP = 3 + 42 + 29 + 14 + 293 + 2893 = 1762 msecs. Note that two RTTHTTP delays are needed to fetch the base HTML object - one RTTHTTP to establish the TCP connection, and one RTTHTTP to send the HTTP request, and receive the HTTP reply. Then, serially, for each of the 8 embedded objects, a delay of 2*RTTHTTP is needed - one RTTHTTP to establish the TCP connection and then one RTTHTTP to perform the HTTP GET/response over that TCP connection.
-
Since there are 8 objects, there's a delay of 88 msec for the DNS query, two RTTHTTP for the base page, and 4*RTTHTTP for the objects since the requests for 5 of these objects can be run in parallel (2 RTTHTTP) and the rest can be done after (2 RTTHTTP). The total is 88 + 186 + 186 + 186 = 646 msec. As in 2 above, 2 RTTHTTP are needed to fetch the base HTML object - one RTTHTTP to establish the TCP connection, and one RTTHTTP to send the HTTP request and receive the HTTP reply containing the base HTML object. Once the base object is received at the client, the 8 HTTP GETS for the embedded objects can proceed in parallel. Each (in parallel) requires two RTTHTTP delays - one RTTHTTP to set up the TCP connection, and one RTTHTTP to perform the HTTP GET/response for an embedded object.
-
Since there are 8 objects, there's a delay of 88 msec for the DNS query. There's also a delay of two RTTHTTP for the base page, and 2 RTTHTTP for the objects. The total is 88 + 186 + 186 = 460 msec.As in 2 and 3 above, two RTTHTTP delays are needed to fetch the base HTML object - one RTTHTTP to establish the TCP connection, and one RTTHTTP to send the HTTP request, and receive the HTTP reply containing the base HTML object. However, with persistent HTTP, this TCP connection will remain open for future HTTP requests, which will therefore not incur a TCP establishment delay. Once the base object is received at the client, the maximum of five requests can proceed in parallel, each retrieving one of the 8 embedded objects. Each (in parallel) requires only one RTTHTTP delay to perform the HTTP GET/response for an embedded object. Once these first five objects have been retrieved, (if necessary) the remaining embedded objects can be retrieved (in parallel). This second round of HTTP GET/response to retreive the remaining embedded objects takes only one more RTTHTTP, since the TCP connection has remained open.
-
The delay when using persistent parallel connections is faster than using nonpersistent parallel connections, which is faster than using nonpersistent serial connections
Consider the figure below, where a client is sending an HTTP GET message to a web server, gaia.cs.umass.edu
Suppose the client-to-server HTTP GET message is the following:
GET /kurose_ross_sandbox/interactive/quotation5.htm HTTP/1.1Host: gaia.cs.umass.eduAccept: text/plain, text/html, image/jpeg, image/gif, audio/vnf.wave, audio/basic, video/mp4, video/wmv,Accept-Language: en-us, en-gb;q=0.7, en;q=0.8, fr, fr-ch, zh, de, ar, csIf-Modified-Since: Thu, 19 Oct 2023 12:28:38 -0700User Agent: Mozilla/5.0 (Windows NT 6.1; WOW64; rv:12.0) Gecko/20100101 Firefox/12.0
-
What is the name of the file that is being retrieved in this GET message?
-
What version of HTTP is the client running?
-
True or False: The client will accept html files
-
True or False: The client will accept jpeg images
-
What is the client's preferred version of English?
-
What is the client's least preferred version of English?
-
True or False: The client will accept the German language
-
True or False: The client already has a cached copy of the file
-
The name of the file is quotation5.htm.
-
The client is running on HTTP/1.1
-
True. In the 'Accept' field the client includes 'text/html' files.
-
True. The client does include 'image/jpeg' in its 'Accept' field.
-
The client's preferred version of English is American English. Any language without a defined q value has a default value of 1
-
The client's least preferred version of English is British English because it has the lowest q value.
-
True. The client does include German in its 'Accepted-Language' field.
-
True. The client has a cached copy of the file that was updated on: Thu, 19 Oct 2023 12:28:38 -0700
Consider the figure below, where the server is sending a HTTP RESPONSE message back the client.
Suppose the server-to-client HTTP RESPONSE message is the following:
HTTP/1.0 404 Not FoundDate: Thu, 19 Oct 2023 19:41:19 +0000Server: Apache/2.2.3 (CentOS)Content-Length: 353Connection: CloseContent-type: image/html
-
Is the response message using HTTP 1.0 or HTTP 1.1?
-
Was the server able to send the document successfully? Yes or No
-
How big is the document in bytes?
-
Is the connection persistent or nonpersistent?
-
What is the type of file being sent by the server in response?
-
What is the name of the server and its version? Write your answer as server/x.y.z
-
Will the ETag change if the resource content at this particular resource location changes? Yes or No
-
The response is using HTTP/1.0
-
Since the response code is 404 Not Found, the document was NOT received successfully.
-
The document is 353 bytes.
-
The connection is nonpersistent.
-
The file type the server is sending is image/html.
-
The name and version of the server is Apache/2.2.3
-
Yes. The Etag is a string that uniquely identifies a resource. If a resource is updated, the Etag will change.
Consider an HTTP server and client as shown in the figure below. Suppose that the RTT delay between the client and server is 30 msecs; the time a server needs to transmit an object into its outgoing link is 1 msecs; and any other HTTP message not containing an object has a negligible (zero) transmission time. Suppose the client again makes 100 requests, one after the other, waiting for a reply to a request before sending the next request.
Assume the client is using HTTP 1.1 and the IF-MODIFIED-SINCE header line. Assume 60% of the objects requested have NOT changed since the client downloaded them (before these 100 downloads are performed)
- How much time elapses (in milliseconds) between the client transmitting the first request, and the completion of the last request?
- (RTT * NUM_PACKETS) + (NUM_PACKETS * (PERCENT__NOT_CACHED / 100) * TRANS_DELAY) = (30 * 100) + (100 * ((100-60) / 100) * 1) = 3040 ms
Look at the scenario below, where Alice sends an email to Bob.
For the questions below, assume both Bob's and Alice's user agents use the POP3 protocol.
-
At point 2 in the diagram, what protocol is being used?
-
At point 4 in the diagram, what protocol is being used?
-
At point 6 in the diagram, what protocol is being used?
-
Does SMTP use TCP or UDP?
-
Is SMTP a 'push' or 'pull' protocol?
-
Is POP3 a 'push' or 'pull' protocol?
-
What port does SMTP use?
-
What port does POP3 use?
-
At point 2 in the diagram, the SMTP protocol is used.
-
At point 4 in the diagram, the SMTP protocol is used.
-
At point 6 in the diagram, the POP3 protocol is used.
-
SMTP uses the TCP protocol.
-
SMTP is a 'push' protocol
-
POP3 is a 'pull' protocol
-
SMTP uses port 25
-
POP3 uses port 110
In this problem, you'll compare the time needed to distribute a file that is initially located at a server to clients via either client-server download or peer-to-peer download. Before beginning, you might want to first review Section 2.5 and the discussion surrounding Figure 2.22 in the text.
The problem is to distribute a file of size F = 10 Gbits to each of these 8 peers. Suppose the server has an upload rate of u = 99 Mbps.
The 8 peers have upload rates of: u1= 18 Mbps, u2= 30 Mbps, u3= 30 Mbps, u4= 11 Mbps, u5= 14 Mbps, u6= 18 Mbps, u7= 12 Mbps, and u8= 13 Mbps
The 8 peers have download rates of: d1= 12 Mbps, d2= 23 Mbps, d3= 17 Mbps, d4= 12 Mbps, d5= 36 Mbps, d6= 27 Mbps, d7= 15 Mbps, and d8= 29 Mbps
-
What is the minimum time needed to distribute this file from the central server to the 8 peers using the client-server model?
-
For the previous question, what is the root cause of this specific minimum time? Answer as 's' or 'ci' where 'i' is the client's number
-
What is the minimum time needed to distribute this file using peer-to-peer download?
-
For question 3, what is the root case of this specific minimum time: the server (s), client (c), or the combined upload of the clients and the server (cu)
-
The minimum time needed to distribute the file = max of: N*F / US and F / dmin = 833.33 seconds.
-
The root cause of the minimum time was c1.
-
The minimum time needed to distribute the file = max of: F / US, F / dmin, and N * F / sum of ui for all i + uS = 833.33 seconds.
-
The root cause of the minimum time was c.
Consider the two 16-bit words (shown in binary) below. Recall that to compute the Internet checksum of a set of 16-bit words, we compute the one's complement sum [1] of the two words. That is, we add the two numbers together, making sure that any carry into the 17th bit of this initial sum is added back into the 1's place of the resulting sum); we then take the one's complement of the result. Compute the Internet checksum value for these two 16-bit words:
10001011 01011010
this binary number is 35674 decimal (base 10)
00001001 00001001
this binary number is 2313 decimal (base 10)
-
What is the sum of these two 16 bit numbers? Don't put any spaces in your answer
-
Using the sum from question 1, what is the checksum? Don't put any spaces in your answer
-
The sum of 10001011 01011010 and 00001001 00001001 = 10010100 01100011
-
The internet checksum is the one's complement of the sum: 10010100 01100011 = 01101011 10011100
Consider the rdt2.2 protocol from the text (pages 209-212). The FSMs for the sender and receiver are shown below:
Suppose that the channel connecting the sender and receiver can corrupt but not lose or reorder packets. Now consider the figure below, which shows four data packets and three corresponding ACKs being exchanged between an rdt 2.2 sender and receiver. The actual corruption or successful transmission/reception of a packet is indicated by the corrupt and OK labels, respectively, shown above the packets in the figure below.
-
At time t=0, what is the sender state?
-
At time t=0, what is the receiver state?
-
At time t=0, what is the sequence/ack # of the packet?
-
At time t=1, what is the sender state?
-
At time t=1, what is the receiver state?
-
At time t=1, what is the sequence/ack # of the packet?
-
At time t=2, what is the sender state?
-
At time t=2, what is the receiver state?
-
At time t=2, what is the sequence/ack # of the packet?
-
At time t=3, what is the sender state?
-
At time t=3, what is the receiver state?
-
At time t=3, what is the sequence/ack # of the packet?
-
How many times is the payload of the received packet passed up to the higher layer?
-
At time t=0, the sender state is: Wait for ACK 0
-
At time t=0, the receiver state is: Wait for 0 from below
-
At time t=0, the sequence # is: 0
-
At time t=1, the sender state is: Wait for ACK 0
-
At time t=1, the receiver state is: Wait for 0 from below
-
At time t=1, the ACK # is: 1
-
At time t=2, the sender state is: Wait for ACK 0
-
At time t=2, the receiver state is: Wait for 0 from below
-
At time t=2, the sequence # is: 0
-
At time t=3, the sender state is: Wait for ACK 0
-
At time t=3, the receiver state is: Wait for 1 from below
-
At time t=3, the ACK # is: 0
-
1 packets were passed up to the higher layer by the receiver.
Consider the RDT 3.0 protocol, for reliably communicating data from a sender to receiver over a channel that can lose or corrupt packets in either direction, and when the maximum delay from sender to receiver and back is not known. The FSMs for the sender and receiver are shown below, with their transitions labeled as SX and RY, respectively.
Now let’s consider the sequence of sender and receiver transitions that would happen when one or more of the following complications occur: a packet (data or ACK) is lost, a timer times out (prematurely or not), or a message is corrupted. One or more of these events has occurred to produce the sequence of transitions below. In the sequence below, one transition has been omitted and replaced with a "*".
Transition Sequence: S0, R0, S1, S2, *, S1, S2, R1, S1, S2, R1, S3, S5, R2, S6, S7, R3, S6, S7, R3, S6, S7, R3, S6, S7, R3, S6, S7, R3, S8
- What is the missing transition? To indicate the missing transition, enter S or R, followed by an index.
- The missing transition is: R1
Consider the figure below in which a TCP sender and receiver communicate over a connection in which the sender->receiver segments may be lost. The TCP sender sends an initial window of 3 segments. Suppose the initial value of the sender->receiver sequence number is 47 and the first 3 segments each contain 685 bytes. The delay between the sender and receiver is 7 time units, and so the first segment arrives at the receiver at t=8. As shown in the figure below, 1 of the 3 segment(s) are lost between the segment and receiver.
-
Give the sequence numbers associated with each of the 3 segments sent by the sender. Format your answer as: a,b,c,...
-
Give the ACK numbers the receiver sends in response to each of the segments. If a segment never arrives use 'x' to denote it, and format your answer as: a,b,c,...
-
The sender's sequence numbers are: 47,732,1417
-
The receiver's ACKs are: 732,1417,x
Suppose that TCP's current estimated values for the round trip time (estimatedRTT) and deviation in the RTT (DevRTT) are 270 msec and 45 msec, respectively (see Section 3.5.3 for a discussion of these variables). Suppose that the next three measured values of the RTT are 360 msec, 320 msec, and 200 msec respectively.
Compute TCP's new value of DevRTT, estimatedRTT, and the TCP timeout value after each of these three measured RTT values is obtained. Use the values of α = 0.125, and β = 0.25. Round your answers to two decimal places after leading zeros.
-
What is the estimatedRTT after the first RTT?
-
What is the RTT Deviation for the the first RTT?
-
What is the TCP timeout for the first RTT?
-
What is the estimatedRTT after the second RTT?
-
What is the RTT Deviation for the the second RTT?
-
What is the TCP timeout for the second RTT?
-
What is the estimatedRTT after the third RTT?
-
What is the RTT Deviation for the the third RTT?
-
What is the TCP timeout for the third RTT?
DevRTT is calculated with the following equation: (1-beta)*DevRTT + beta * |estimatedRTT - sampleRTT|
estimatedRTT is calculated with the following equation: (1-alpha)estimatedRTT + alphasampleRTT
TCP timeout is calculated with the following equation: estimatedRTT + (4*DevRTT)
-
The estimatedRTT for RTT1 is 281.25
-
The DevRTT for RTT1 is 56.25
-
The timeout for RTT1 is 506.25
-
The estimatedRTT for RTT2 is 286.09
-
The DevRTT for RTT2 is 51.88
-
The timeout for RTT2 is 493.59
-
The estimatedRTT for RTT3 is 275.33
-
The DevRTT for RTT3 is 60.43
-
The timeout for RTT3 is 517.05
Consider the figure below, which plots the evolution of TCP's congestion window at the beginning of each time unit (where the unit of time is equal to the RTT); see Figure 3.53 in the text. In the abstract model for this problem, TCP sends a "flight" of packets of size cwnd at the beginning of each time unit. The result of sending that flight of packets is that either (i) all packets are ACKed at the end of the time unit, (ii) there is a timeout for the first packet, or (iii) there is a triple duplicate ACK for the first packet. In this problem, you are asked to reconstruct the sequence of events (ACKs, losses) that resulted in the evolution of TCP's cwnd shown below.
Consider the evolution of TCP's congestion window in the example above and answer the following questions. The initial value of cwnd is 1 and the initial value of ssthresh (shown as a red +) is 8.
-
Give the times at which TCP is in slow start. Format your answer like: 1,3,5,9 (If none submit blank)
-
Give the times at which TCP is in congestion avoidance. Format your answer like: 1,3,5,9 (If none submit blank)
-
Give the times at which TCP is in fast recovery. Format your answer like: 1,3,5,9 (If none submit blank)
-
Give the times at which packets are lost via timeout. Format your answer like: 1,3,5,9 (If none submit blank)
-
Give the times at which packets are lost via triple ACK. Format your answer like: 1,3,5,9 (If none submit blank)
-
Give the times at which the value of ssthresh changes (if it changes between t=3 and t=4, use t=4 in your answer)
-
The times where TCP is in slow start are: 1,2,3,13,14,15,16,22,23,26,27,34,35,36,39,40
-
The times where TCP is in congestion avoidance are: 4,5,6,7,8,9,10,11,12,17,18,19,20,21,24,25,28,29,31,32,33,37,38
-
The times where TCP is in fast recovery are: 30
-
The times where TCP has a loss by timeout are: 12,15,21,25,33,38
-
The times where TCP has a loss by triple duplicate ACK are: 29
-
The times where the ssthresh changes are: 16,22,26,34,39
The complete solution is shown in the figure below:
- For intervals of time when TCP is in slow start, the plotted value of cwnd is shown as a green square
- For intervals of time when TCP is in congestion avoidance, the plotted value of cwnd is shown as a yellow square
- For intervals of time when TCP is in fast reccovery, the plotted value of cwnd is shown as an orange square
- The values for ssthresh are shown following a change as a red plus sign
- A flight of packets experiencing a loss has the loss type (which determines the next value of cwnd) labeled above
Consider the figure below in which a TCP sender and receiver communicate over a connection in which the segments can be lost. The TCP sender wants to send a total of 10 segments to the receiver and sends an initial window of 5 segments at t = 1, 2, 3, 4, and 5, respectively. Suppose the initial value of the sequence number is 104 and every segment sent to the receiver each contains 957 bytes. The delay between the sender and receiver is 7 time units, and so the first segment arrives at the receiver at t = 8, and an ACK for this segment arrives at t = 15. As shown in the figure, 1 of the 5 segments is lost between the sender and the receiver, but one of the ACKs is lost. Assume there are no timeouts and any out of order segments received are thrown out.
-
What is the sequence number of the segment sent at t=1?
-
What is the sequence number of the segment sent at t=2?
-
What is the sequence number of the segment sent at t=3?
-
What is the sequence number of the segment sent at t=4?
-
What is the sequence number of the segment sent at t=5?
-
What is the value of the ACK sent at t=8? (If segment lost, write 'x')
-
What is the value of the ACK sent at t=9? (If segment lost, write 'x')
-
What is the value of the ACK sent at t=10? (If segment lost, write 'x')
-
What is the value of the ACK sent at t=11? (If segment lost, write 'x')
-
What is the value of the ACK sent at t=12? (If segment lost, write 'x')
-
What is the sequence number of the segment sent at t = 15? (If ACK never arrives, write 'x')
-
What is the sequence number of the segment sent at t = 16? (If ACK never arrives, write 'x')
-
What is the sequence number of the segment sent at t = 17? (If ACK never arrives, write 'x')
-
What is the sequence number of the segment sent at t = 18? (If ACK never arrives, write 'x')
-
What is the sequence number of the segment sent at t = 19? (If ACK never arrives, write 'x')
-
The sequence number of the first segment is the starting sequence number, which is 104.
-
The sequence number of the second segment is = 104 + 957 = 1061.
-
The sequence number of the third segment is = 1061 + 957 = 2018.
-
The sequence number of the fourth segment is = 2018 + 957 = 2975.
-
The sequence number of the fifth segment is = 2975 + 957 = 3932.
-
The ACK value is the sequence number of the next expected segment, which is 1061.
-
The ACK value is the sequence number of the next expected segment, which is 2018.
-
The ACK value is the sequence number of the next expected segment, which is 2975.
-
Since the segment was lost, the ACK is never sent, so the answer is x.
-
The ACK value is the sequence number of the next expected segment, which is 2975.
-
The sequence number of this segment is calculated the same way as the first five segments. The sequence number is 4889.
-
Since there was nothing to send (as we're waiting for ACKs), the answer is x.
-
The sequence number of this segment is calculated the same way as the first five segments. The sequence number is 5846.
-
The sequence number of this segment is calculated the same way as the first five segments. The sequence number is 6803.
-
Since there was nothing to send (as we're waiting for ACKs), the answer is x.
In the scenario below, the left and right clients communicate with a server using UDP sockets. The same socket at the server is used to communicate with both clients. The Python code used to create the sockets is shown in the figure. Consider the four transport-layer packets – A, B, C and D – shown in the figure below.
-
What is the source port # for packet A?
-
What is the destination port # for packet A?
-
What is the source port # for packet B?
-
What is the destination port # for packet B?
-
What is the source port # for packet D?
-
What is the destination port # for packet D?
-
What is the source port # for packet C?
-
What is the destination port # for packet C?
-
The source port for packet A is port 7478.
-
The destination port for packet A is port 7376.
-
The source port for packet B is port 7376.
-
The destination port for packet B is port 7478.
-
The source port for packet D is port 7376.
-
The destination port for packet D is port 7478.
-
The source port for packet C is port 7478.
-
The destination port for packet C is port 7376.
In the scenario below, the left and right TCP clients communicate with a TCP server using TCP sockets. The Python code used to create a single welcoming socket in the server is shown in the figure (the welcoming socket itself is not shown graphically); code is also shown for the client sockets as well. The three sockets shown in server were created as a result of the server accepting connection requests on this welcoming socket from the two clients (one connection from the client on the left, and two connections from the client on the right).
-
What is the source port # for packet D?
-
What is the destination port # for packet D?
-
What is the source port # for packet C?
-
What is the destination port # for packet C?
-
What is the source port # for packet A?
-
What is the destination port # for packet A?
-
What is the source port # for packet B?
-
What is the destination port # for packet B?
-
The source port for packet D is port 6918.
-
The destination port for packet D is port 5429.
-
The source port for packet C is port 5641.
-
The destination port for packet C is port 5429.
-
The source port for packet A is port 6595.
-
The destination port for packet A is port 5429.
-
The source port for packet B is port 5429.
-
The destination port for packet B is port 6595.
-
Suppose a datagram arrives at the router, with destination address 00001100. To which interface will this datagram be forwarded using longest-prefix matching?
-
Suppose a datagram arrives at the router, with destination address 11100010. To which interface will this datagram be forwarded using longest-prefix matching?
-
Suppose a datagram arrives at the router, with destination address 01010111. To which interface will this datagram be forwarded using longest-prefix matching?
-
Since the address is 00001100, it will go to interface 3.
-
Since the address is 11100010, it will go to interface 4.
-
Since the address is 01010111, it will go to interface 5.
-
At t=1, which packet is sent out? Give the packet # or 'n/a' if applicable
-
At t=2, which packet is sent out? Give the packet # or 'n/a' if applicable
-
At t=3, which packet is sent out? Give the packet # or 'n/a' if applicable
-
At t=4, which packet is sent out? Give the packet # or 'n/a' if applicable
-
At t=5, which packet is sent out? Give the packet # or 'n/a' if applicable
-
At t=6, which packet is sent out? Give the packet # or 'n/a' if applicable
-
At t=7, which packet is sent out? Give the packet # or 'n/a' if applicable
-
At t=8, which packet is sent out? Give the packet # or 'n/a' if applicable
-
At t=9, which packet is sent out? Give the packet # or 'n/a' if applicable
-
At t=10, which packet is sent out? Give the packet # or 'n/a' if applicable
-
At t=11, which packet is sent out? Give the packet # or 'n/a' if applicable
-
At time t=1, the packet sent is 1.
-
At time t=2, the packet sent is 2.
-
At time t=3, the packet sent is 3.
-
At time t=4, the packet sent is 4.
-
At time t=5, the packet sent is 5.
-
At time t=6, the packet sent is 6.
-
At time t=7, the packet sent is 7.
-
At time t=8, the packet sent is 8.
-
At time t=9, the packet sent is 9.
-
At time t=10, the packet sent is 10.
-
At time t=11, the packet sent is 11.
-
At time t=1, the packet sent is 1.
-
At time t=2, the packet sent is 2.
-
At time t=3, the packet sent is 3.
-
At time t=4, the packet sent is 7.
-
At time t=5, the packet sent is 8.
-
At time t=6, the packet sent is 9.
-
At time t=7, the packet sent is 10.
-
At time t=8, the packet sent is 11.
-
At time t=9, the packet sent is 4.
-
At time t=10, the packet sent is 5.
-
At time t=11, the packet sent is 6.
-
At time t=1, the packet sent is 1.
-
At time t=2, the packet sent is 2.
-
At time t=3, the packet sent is 3.
-
At time t=4, the packet sent is 7.
-
At time t=5, the packet sent is 4.
-
At time t=6, the packet sent is 5.
-
At time t=7, the packet sent is 8.
-
At time t=8, the packet sent is 6.
-
At time t=9, the packet sent is 9.
-
At time t=10, the packet sent is 10.
-
At time t=11, the packet sent is 11.
-
At time t=1, the packet sent is 1.
-
At time t=2, the packet sent is 2.
-
At time t=3, the packet sent is 3.
-
At time t=4, the packet sent is 7.
-
At time t=5, the packet sent is 8.
-
At time t=6, the packet sent is 9.
-
At time t=7, the packet sent is 10.
-
At time t=8, the packet sent is 11.
-
At time t=9, the packet sent is 4.
-
At time t=10, the packet sent is 5.
-
At time t=11, the packet sent is 6.
-
Is the address space public or private?
-
How many hosts can there be in this address space?
-
What is the subnet address of subnet A? (CIDR notation)
-
What is the broadcast address of subnet A?
-
What is the starting address of subnet A?
-
What is the ending address of subnet A?
-
What is the subnet address of subnet B? (CIDR notation)
-
What is the broadcast address of subnet B?
-
What is the starting address of subnet B?
-
What is the ending address of subnet B?
-
The address 12.5.14.0/24 is public.
-
Maximum number of hosts = 2^x - 2 = 2^8 - 2 = 254. The reason we have to subtract 2 from the final number is because there are always 2 addresses allocated for each address block: the subnet ID (the first address) and the broadcast address (the last address); for example, if you have 5 bits for hosts, you can have 30 hosts, because 2 of the addresses are for the subnet ID and the broadcast address which when added equals 32, which is 2^5.
-
Subnet A has 55 hosts, so it will need at least 57 addresses (for the subnet ID and broadcast address). The least number of bits that satisfy this is 6 bits. Knowing that, we take the prior subnet and add 64, the result of which is 12.5.14.128/26
-
The broadcast address of subnet A (12.5.14.128/26) is 12.5.14.191, because it is the last address in the IP range.
-
The first IP address of subnet A (12.5.14.128/26) is 12.5.14.129, found by adding 1 to the subnet address.
-
The last IP address of subnet A (12.5.14.128/26) is 12.5.14.190, found by subtracting 1 from the broadcast address (12.5.14.191).
-
Similar to the prior subnet, subnet B has 83 hosts, so it will need at least 85 addresses (for the subnet ID and broadcast address). The least number of bits that satisfy this is 7 bits. Knowing that, we take the prior subnet and add 128, the result of which is 12.5.14.0/25
-
The broadcast address of subnet B (12.5.14.0/25) is 12.5.14.127, because it is the last address in the IP range.
-
The first IP address of subnet B (12.5.14.0/25) is 12.5.14.1, found by adding 1 to the subnet address.
-
The last IP address of subnet B (12.5.14.0/25) is 12.5.14.126, found by subtracting 1 from the broadcast address (12.5.14.127)
-
Consider the datagram at step 1, after it has been sent by the host but before it has reached the router. What is the source IP address for this datagram?
-
At step 1, what is the destination IP address?
-
Now consider the datagram at step 2, after it has been transmitted by the router. What is the source IP address for this datagram?
-
At step 2, what is the destination IP address for this datagram?
-
Will the source port have changed? Yes or No.
-
Now consider the datagram at step 3, just before it is received by the router. What is the source IP address for this datagram?
-
At step 3, what is the destination IP address for this datagram?
-
Last, consider the datagram at step 4, after it has been transmitted by the router but before it has been received by the host. What is the source IP address for this datagram?
-
At step 4, what is the destination IP address for this datagram
-
The source address will be the local host's IP, which is 10.0.1.15
-
The destination address will be the remote machine's IP, which is 128.119.177.183
-
The source address will be the router's public IP, which is 135.122.200.220
-
The destination address will be the remote machine's IP, which is 128.119.177.183
-
Yes, the NAT will change the source port.
-
The source address will be the remote machine's IP, which is 128.119.177.183
-
The destination address will be the router's public IP, which is 135.122.200.220
-
The source address will be the remote machine's IP, which is 128.119.177.183
-
The destination address will be the local host's IP, which is 10.0.1.15
-
No, an entry is made when there's an outbound request, which only happens between step 1 and step 2.
-
Is the datagram being forwarded from B to c an IPv4 or IPv6 datagram?
-
What is the source address of this B to c datagram?
-
What is the destination address of this B to c datagram?
-
Is this B to c datagram encapsulating another datagram? Yes or No.
-
What is the source address of this encapsulated datagram?
-
What is the destination address of this encapsulated datagram?
-
Is the datagram being forwarded from c to d an IPv4 or IPv6 datagram?
-
What is the source address of this c to d datagram?
-
What is the destination address of this c to d datagram?
-
Is this c to d datagram encapsulating another datagram? Yes or No.
-
What is the source address of this encapsulated datagram?
-
What is the destination address of this encapsulated datagram?
-
Is the datagram being forwarded from d to b an IPv4 or IPv6 datagram?
-
What is the source address of this d to b datagram?
-
What is the destination address of this d to b datagram?
-
Is this d to b datagram encapsulating another datagram? Yes or No.
-
What is the source address of this encapsulated datagram?
-
What is the destination address of this encapsulated datagram?
-
Is the datagram being forwarded from b to F an IPv4 or IPv6 datagram?
-
What is the source address of this b to F datagram?
-
What is the destination address of this b to F datagram?
-
Is this b to F datagram encapsulating another datagram? Yes or No.
-
What is the source address of this encapsulated datagram?
-
What is the destination address of this encapsulated datagram?
-
Is the datagram being forwarded from F to D an IPv4 or IPv6 datagram?
-
What is the source address of this F to D datagram?
-
What is the destination address of this F to D datagram?
-
Is this F to D datagram encapsulating another datagram? Yes or No.
-
What router is the 'tunnel entrance'? Give the router's letter
-
What router is the 'tunnel exit'? Give the router's letter
-
Which protocol encapsulates the other, IPv4 or IPv6?
-
The datagram is an IPv4 datagram.
-
The source IP address is 8.160.132.48
-
The destination IP address is 18.178.57.239
-
Yes, the datagram is encapsulated.
-
The source address of this encapsulated datagram is FB43:DDB6:212F:27F9:68DB:5812:4B5E:3F85
-
The destination address of this encapsulated datagram is 777A:84D4:4A7A:443B:DE75:67FA:8983:8159
-
The datagram is an IPv4 datagram.
-
The source IP address is 8.160.132.48
-
The destination IP address is 18.178.57.239
-
Yes, the datagram is encapsulated.
-
The source address of this encapsulated datagram is FB43:DDB6:212F:27F9:68DB:5812:4B5E:3F85
-
The destination address of this encapsulated datagram is 777A:84D4:4A7A:443B:DE75:67FA:8983:8159
-
The datagram is an IPv4 datagram.
-
The source IP address is 8.160.132.48
-
The destination IP address is 18.178.57.239
-
Yes, the datagram is encapsulated.
-
The source address of this encapsulated datagram is FB43:DDB6:212F:27F9:68DB:5812:4B5E:3F85
-
The destination address of this encapsulated datagram is 777A:84D4:4A7A:443B:DE75:67FA:8983:8159
-
The datagram is an IPv4 datagram.
-
The source IP address is 8.160.132.48
-
The destination IP address is 18.178.57.239
-
Yes, the datagram is encapsulated.
-
The source address of this encapsulated datagram is FB43:DDB6:212F:27F9:68DB:5812:4B5E:3F85
-
The destination address of this encapsulated datagram is 777A:84D4:4A7A:443B:DE75:67FA:8983:8159
-
The datagram is an IPv6 datagram.
-
The source IP address is FB43:DDB6:212F:27F9:68DB:5812:4B5E:3F85
-
The destination IP address is 777A:84D4:4A7A:443B:DE75:67FA:8983:8159
-
No, the datagram is NOT encapsulated.
-
The tunnel entrance is router B
-
The tunnel exit is router F
-
IPv4, in order to maintain compatibility with existing IPv4 infrastructure, IPv6 datagrams are put in the payload of an IPv4 datagram. These IPv4 datagrams are passed on until it reaches a router which supports IPv6, where the IPv6 datagram is decapsulated and passed on.
-
For router s1, what should the value of the 'IP Src' be? Pick either a specific address (including CIDR), any, or none
-
For router s1, what should the value of the 'IP Dst' be? Pick either a specific address (including CIDR), any, or none
-
For router s1, what should the value of the 'Src Port' be? Pick either a specific port, or any
-
For router s1, what should the value of the 'Dst Port' be? Pick either a specific port, or any
-
For router s1, what should the value of the 'IP Proto' be? Pick either TCP, UDP, or any
-
For router s1, what should the action of the rule be? Some examples include forward, allow, deny, etc
-
For router s1, what interface should the packets be forwarded to?
-
For router s4, what should the value of the 'IP Src' be? Pick either a specific address (including CIDR), any, or none
-
For router s4, what should the value of the 'IP Dst' be? Pick either a specific address (including CIDR), any, or none
-
For router s4, what should the value of the 'Src Port' be? Pick either a specific port, or any
-
For router s4, what should the value of the 'Dst Port' be? Pick either a specific port, or any
-
For router s4, what should the value of the 'IP Proto' be? Pick either TCP, UDP, or any
-
For router s4, what should the action of the rule be? Some examples include forward, allow, deny, etc
-
For router s4, what interface should the packets be forwarded to?
(Q1-Q7) Rule 1. | IP_Src=128.122/16, IP_Dst=128.119/16, Src_Port=Any, Dst_Port=Any, IP_Protocol=Any, Action=Forward(1) |
(Q8-Q14) Rule 2. | IP_Src=128.122/16, IP_Dst=128.119/16, Src_Port=Any, Dst_Port=Any, IP_Protocol=Any, Action=Forward(2) |
-
What is the shortest distance to node v and what node is its predecessor? Write your answer as n,p
-
What is the shortest distance to node y and what node is its predecessor? Write your answer as n,p
-
What is the shortest distance to node x and what node is its predecessor? Write your answer as n,p
-
The minimum distance from node u to node v is 6, and node v's predecessor is node u. The full answer was: 6,u
-
The minimum distance from node u to node y is 10, and node y's predecessor is node w. The full answer was: 10,w
-
The minimum distance from node u to node x is 5, and node x's predecessor is node u. The full answer was: 5,u
-
For link X, what is the cost associated with this link? If the answer can't be determined given the information, respond with 'n/a'
-
For link Y, what is the cost associated with this link? If the answer can't be determined given the information, respond with 'n/a'
-
The prior node in the path to V is W, and we know the shortest distance of both V (12) and W (3), so 12 - 3 = 9 which is X.
-
The prior node in the path to U is W, and we know the shortest distance of both U (8) and W (3), so 8 - 3 = 5 which is Y.
-
When the algorithm converges, what are the distance vectors from router 'U' to all routers? Write your answer as u,v,w,x,y
-
What are the initial distance vectors for router 'X'? Write your answer as u,v,w,x,y and if a distance is ∞, write 'x'
-
The phrase 'Good news travels fast' is very applicable to distance vector routing when link costs decrease; what is the name of the problem that can occur when link costs increase?
-
When the algorithm converges, router U has distance vectors (u,v,w,x,y) = (0,4,8,5,10)
-
The initial distance vectors of router X are: (u,v,w,x,y) = (x,1,3,0,5) where x is ∞
-
It is called the 'Count to Infinity' problem.
-
For figure 1, compute the two-dimensional parity bits for the 16 columns. Combine the bits into one string
-
For figure 1, compute the two-dimensional parity bits for the 5 rows (starting from the top). Combine the bits into one string
-
For figure 1, compute the parity bit for the parity bit row from question 1. Assume that the result should be even.
-
For figure 2, indicate the row and column with the flipped bit (format as: x,y), assuming the top-left bit is 0,0
-
For figure 3, is it possible to detect and correct the bit flips? Yes or No
The full solution for figure 1 is shown below:
10010100 00110101 1
00110100 11110010 0
00111110 10001001 0
01011011 10001100 0
00010011 00000110 1
11010110 11000100 0
-
The parity bits for the 16 columns is: 11010110 11000100
-
The parity bits for the 5 rows is: 10001
-
The parity bit for the parity row is: 0
-
The bit that was flipped in figure 2 is (3,4):
10010001 10110111 1
11100000 10001010 0
00011000 10010001 1
00110001 10010010 0
11101011 01111010 0
10100011 01000100 0
For figure 3, the bit that was flipped is (11,3):
00100001 01010011 0
11101101 10011010 0
01011101 01010111 0
11110101 00100110 0
00100001 11011101 0
01000101 01110101 0
- Yes, with 2D parity, you can detect and correct the a single flipped bit
Consider the Cyclic Redundancy Check (CRC) algorithm discussed in Section 6.2.3 of the text. Suppose that the 4-bit generator (G) is 1001, that the data payload (D) is 10011101 and that r = 3.
- What are the CRC bits (R) associated with the data payload D, given that r = 3?
To compute the CRC, we begin by taking the value of D, 10011101, and multiplying it by 2^3, giving 10011101000. We then divide this number by the generator bits [G] = 1001, using modulo-2 arithmetic. The final remainder, R, after this division are then the CRC bits. Here is that calculation:
We've computed the remainder as R = 100 and the quotient n = 10001100. You should verify that n*G XOR R is indeed equal to 10011101000. You can use this calculator to do the modulo-2 arithmetic if you don't want to do it by hand.
Assume that there are 3 active nodes, each of which has an infinite supply of frames they want to transmit, and these frames have a constant size of L bits. If two or more frames collide, then all nodes will detect the collision.
There are two versions of the Aloha protocol: Slotted and Pure. In this problem we will be looking at the efficiency of these two variations. In the case of Slotted Aloha, frames will be sent only at the beginning of a time slot, frames take an entire time slot to send, and the clocks of all nodes are synchronized.
Please round all answers to 2 decimal places
-
Given a probability of transmission p = 0.21, what is the maximum efficiency?
-
Given a probability of transmission p = 0.74, what is the maximum efficiency?
-
The efficiency given p = 0.21 is: Np(1 - p)^2(N - 1) = 3 * 0.21 * (1 - 0.21)^2(3 - 1) = 0.25 or 25% efficiency.
-
The efficiency given p = 0.74 is: Np(1 - p)^2(N - 1) = 3 * 0.74 * (1 - 0.74)^2(3 - 1) = 0.01 or 1% efficiency.
-
The efficiency given p = 0.21 is: Np(1 - p)^(N - 1) = 3 * 0.21 * (1 - 0.21)^(3 - 1) = 0.39 or 39% efficiency.
-
The efficiency given p = 0.74 is: Np(1 - p)^(N - 1) = 3 * 0.74 * (1 - 0.74)^(3 - 1) = 0.15 or 15% efficiency.
-
Suppose all nodes are implementing the Aloha protocol. For each message, indicate the time at which each transmission begins. Separate each value with a comma and no spaces.
-
Which messages transmit successfully? Write your answer as a comma seperated list with no spaces using the messages' numbers
-
The list of times for frame transmissions is: 0.2,0.9,1.4,1.5,1.8,2.2,2.5,2.9,3.2,4.9
-
The list of successful frames is: 10
-
The list of times for frame transmissions is: 1,1,2,2,2,3,3,3,4,5
-
The list of successful frames is: 9,10
-
Suppose all nodes are implementing Carrier Sense Multiple Access (CSMA), but without collision detection. Suppose that the time from when a message transmission begins until it is beginning to be received at other nodes is 0.4 time units. (Thus if a node begins transmitting a message at t=2.0 and transmits that message until t=3.0, then any node performing carrier sensing in the interval [2.4, 3.4] will sense the channel busy.) For each message, indicate the time at which each message transmission begins, or indicate that message transmission does not begin due to a channel that is sensed busy when that message arrives. Separate each value with a comma and no spaces, and if the channel is sensed busy, substitute it with 's'
-
Which messages transmitted successfully? Write your answer as a comma seperated list with no spaces using the messages' numbers
-
The list of times for frame transmissions is: 0.2,s,s,s,1.8,s,s,s,3.2,4.9
-
The list of successful frames is: 1,5,9,10
-
Suppose all nodes are implementing Carrier Sense Multiple Access (CSMA), with collision detection (CSMA/CD). Suppose that the time from when a message transmission begins until it is beginning to be received at other nodes is 0.4 time units, and assume that a node can stop transmission instantaneously when a message collision is detected. (Thus if a node begins transmitting a message at t=2.0 and transmits that message until t=3.0, then any node performing carrier sensing in the interval [2.4, 3.4] will sense the channel busy.) For each message, indicate the time at which each message transmission begins, or indicate that message transmission does not begin due to a channel that is sensed busy when that message arrives. Separate each value with a comma and no spaces, and if the channel is sensed busy, substitute it with 's'
-
Which messages transmitted successfully? Write your answer as a comma seperated list with no spaces using the messages' numbers
-
At what time did each message stop transmitting due to a collision. Write your answer as a comma seperated list with no spaces using the messages' numbers in order, and if a message didn't stop, write 'x' for that message
-
The list of times for frame transmissions is: 0.2,s,s,s,1.8,s,s,s,3.2,4.9
-
The list of successful frames is: 1,5,9,10
-
The list of stopped packet times is: x,x,x,x,x,x,x,x,x,x
-
What is the source mac address at point 6?
-
What is the destination mac address at point 6?
-
What is the source IP address at point 6?
-
What is the destination IP address at point 6?
-
Do the source and destinaton mac addresses change at point 5? Answer with yes or no.
-
The source mac address at point 6 is 90-54-8A-61-C5-F5
-
The destination mac address at point 6 is 0E-F7-40-E8-B7-25
-
The source IP address at point 6 is 128.119.40.206
-
The destination IP address at point 6 is 128.119.40.64
-
No, datagrams can be sent across the subnet via the link layer in one go
-
At t=1, what is the source entry for switch 1? Format your answer as letter,number or 'n/a'
-
At t=1, what is the destination entry for switch 1? Format your answer as letter,number or 'n/a'
-
At t=1, what is the source entry for switch 2? Format your answer as letter,number or 'n/a'
-
At t=1, what is the destination entry for switch 2? Format your answer as letter,number or 'n/a'
-
At t=2, what is the source entry for switch 1? Format your answer as letter,number or 'n/a'
-
At t=2, what is the destination entry for switch 1? Format your answer as letter,number or 'n/a'
-
At t=2, what is the source entry for switch 2? Format your answer as letter,number or 'n/a'
-
At t=2, what is the destination entry for switch 2? Format your answer as letter,number or 'n/a'
-
At t=3, what is the source entry for switch 1? Format your answer as letter,number or 'n/a'
-
At t=3, what is the destination entry for switch 1? Format your answer as letter,number or 'n/a'
-
At t=3, what is the source entry for switch 2? Format your answer as letter,number or 'n/a'
-
At t=3, what is the destination entry for switch 2? Format your answer as letter,number or 'n/a'
-
At t=4, what is the source entry for switch 1? Format your answer as letter,number or 'n/a'
-
At t=4, what is the destination entry for switch 1? Format your answer as letter,number or 'n/a'
-
At t=4, what is the source entry for switch 2? Format your answer as letter,number or 'n/a'
-
At t=4, what is the destination entry for switch 2? Format your answer as letter,number or 'n/a'
-
At time t=1, (C,3) is added as an entry to switch table 1.
-
At time t=1, (B,2) is added as an entry to switch table 1.
-
At time t=1, (C,8) is added as an entry to switch table 2.
-
At time t=1, switch table 2 doesn't observe this frame
-
At time t=2, (H,7) is added as an entry to switch table 1.
-
At time t=2, (D,4) is added as an entry to switch table 1.
-
At time t=2, (H,11) is added as an entry to switch table 2.
-
At time t=2, (D,8) is added as an entry to switch table 2.
-
At time t=3, (A,1) is added as an entry to switch table 1.
-
At time t=3, since the entry for computer B in switch table 1 already exists, no new table entry is made
-
At time t=3, switch table 2 doesn't observe this frame
-
At time t=3, (n/a) is added as an entry to switch table 2.
-
At time t=3, switch table 2 doesn't observe this frame
-
At time t=4, switch table 1 doesn't observe this frame
-
At time t=4, switch table 1 doesn't observe this frame
-
At time t=4, (K,14) is added as an entry to switch table 2.
-
At time t=4, since the entry for computer H in switch table 2 already exists, no new table entry is made
-
At t=2, what two nodes communicated? Write your answer in alphabetical order as x,y (If there is only enough information for 1 node, write that, and if there's no information, write 'n/a')
-
At t=5, what two nodes communicated? Write your answer in alphabetical order as x,y (If there is only enough information for 1 node, write that, and if there's no information, write 'n/a')
-
At t=1, what two nodes communicated? Write your answer in alphabetical order as x,y (If there is only enough information for 1 node, write that, and if there's no information, write 'n/a')
-
At t=7, what two nodes communicated? Write your answer in alphabetical order as x,y (If there is only enough information for 1 node, write that, and if there's no information, write 'n/a')
-
The transmission at t=2 was I-->L, so the answer is n/a.
-
The transmission at t=5 was K-->L, so the answer is K,L.
-
The transmission at t=1 was L-->K, so the answer is L.
-
The transmission at t=7 was G-->D, so the answer is D,G.