CN (1)
CN (1)
CN (1)
5. q
Purpose of Flow Control:
When a packet is corrupted or lost, the receiving transport layer can somehow inform the sending transport layer to
resend that packet using the sequence number.
Packets are numbered sequentially. If the header of the packet allows m bits for the sequence number, the sequence
numbers range from 0 to 2m – 1.
Acknowledgment Numbers
• ACK (Positive): Confirms successful receipt and indicates the next expected packet.
The transport layer at the sender gets a message from its application layer, makes a packet out of it(encapsulates), and
sends the packet to the Transport layer at the receiver’s end
The transport layer at the receiver receives a packet from its network layer, extracts the message (Decapsulates) from
the packet, and delivers the message to its application layer. The transport layers of the sender and receiver provide
transmission services for their application layers. We assume that the receiver can never be overwhelmed with
incoming packets.
Connection-Oriented:
A connection is established between sender and receiver before communication.
Flow and Error Control:
Ensures smooth data flow and error handling during transmission.
Sliding Window Size of 1:
Only one packet is sent at a time
Sending Process:
The sender sends a packet and waits for acknowledgment before sending the next one.
Error Detection:
A checksum is added to each packet to detect corruption.
Timer Mechanism:
The sender starts a timer after sending a packet.
If acknowledgment is received before the timer expires, the sender sends the next packet.
Retransmission on Timeout:
If the timer expires, the sender resends the last packet, assuming it was lost or corrupted.
A copy of the packet is kept until acknowledgment is received.
• To improve the efficiency of transmission (to fill the pipe), multiple packets must be in transition while the
sender is waiting for acknowledgment.
• Sender can send several packets before receiving acknowledgments, but the receiver can only buffer one
packet.
• We keep a copy of the sent packets until the acknowledgments arrive, data packets and acknowledgments
can be in the channel at the same time.
• The sequence numbers are modulo 2m, where m is the size of the sequence number field in bits.
• An acknowledgment number in this protocol is cumulative and defines the sequence number of the next
expected packet.
Selective-Repeat
Protocol :
The Go-Back-N protocol is inefficient if the underlying network protocol loses a lot of packets. Each time a single
packet is lost or corrupted, the sender resends all outstanding packets, even though some of these packets may have
been received safe and sound but out of order. If the network layer is losing many packets because of congestion in the
network, the resending of all of these outstanding packets makes the congestion worse, and eventually more packets
are lost. Selective-Repeat (SR) protocol, has been devised, which resends only selective packets, those that are
actually lost.
• The Selective-Repeat protocol also uses two windows: a send window and a receive window.
• The maximum size of the send window is much smaller; it is 2m−1
• The receive window is the same size as the send window.
Out-of-Order Packet Handling: The receiver can store packets that arrive out of order until the missing packets are
received.
Order of Delivery: Packets are delivered to the application layer only in the correct order.
• The receiver never delivers packets out of order to the application layer.
UDP Services
Process-to-Process Communication: Process-to-process communication using socket addresses, a combination of IP
addresses and port numbers.
Connectionless Services:
• Each user datagram sent by UDP is an independent datagram.
• There is no relationship between the different user datagrams even if they are coming from the same source process
and going to the same destination program.
• UDP cannot send a stream of data to UDP and expect UDP to chop them into different, related user datagrams
Flow Control: UDP is a very simple protocol. There is no flow control, and hence no window mechanism. The
receiver may overflow with incoming messages.
Error Control: There is no error control mechanism in UDP except for the checksum, sender does not know if a
message has been lost or duplicated. When the receiver detects an error through the checksum, the user datagram is
silently discarded.
Checksum: UDP checksum calculation includes three sections: a pseudo header, the UDP header, and the data coming
from the application layer.
APPLICATIONS
Connectionless Service:
• Packets are independent of each other.
• Advantage: Ideal for short, quick exchanges (e.g., DNS).
o Connection-oriented protocols need 9 packets exchanged; UDP needs only 2.
Lack of Error Control:
• UDP does not ensure reliable delivery (no error checks or retransmissions).
• Advantage: Suitable for real-time applications (e.g., Skype, live video).
o Real-time calls prefer UDP since retransmissions might cause delays.
Lack of Congestion Control:
• UDP sends data without worrying about network congestion.
• Advantage: Avoids adding to congestion unlike TCP, which may resend lost packets and increase traffic.
TCP SERVICES :
1. Process-to-Process Communication:
Process-to-process communication using port numbers.
2. Stream Delivery Service:
• Data is delivered as a continuous stream of bytes.
• TCP connects two processes via an "imaginary tube" for seamless data transfer.
• The sender writes data into the stream, and the receiver reads from it.
3. Sending and Receiving Buffers:
• Buffers handle differences in reading/writing speeds between sender and receiver.
• Each direction (send and receive) has its own buffer:
o Sender Buffer:
▪ White section: Empty space for new data.
▪ Colored section: Data sent but not yet acknowledged.
▪ Shaded section: Data ready to be sent.
▪ Acknowledged data frees up space in the buffer for reuse.
o Receiver Buffer:
▪ White section: Space for incoming data.
▪ Colored section: Data ready for the application to read.
▪ Read data frees up buffer space for new incoming data.
4. Segments:
• Data is divided into smaller units called segments.
• Each segment:
o Contains a TCP header for control.
o Is encapsulated in an IP datagram for transmission.
• Segment sizes vary, often carrying hundreds or thousands of bytes.
5. Full-Duplex Communication:
• Data flows simultaneously in both directions.
6. Multiplexing and Demultiplexing:
• Multiplexing: Combines data from multiple processes at the sender.
• Demultiplexing: Delivers data to the correct process at the receiver.
7. Connection-Oriented Service:
• TCP ensures a logical connection is established before data transfer begins.
• Enables bidirectional data exchange and orderly termination of the connection after communication.
Reliable Service: TCP is a reliable transport protocol. It uses an acknowledgment mechanism to check the safe and
sound arrival of data.
14. Segment format
Header and Data:
o Header size: 20 to 60 bytes.
▪ Minimum: 20 bytes (no options).
▪ Maximum: 60 bytes (with options).
o Follows the data from the application program.
Header Fields:
1. Source Port Address:
o 16-bit field.
o Specifies the port number of the sending application.
2. Destination Port Address:
o 16-bit field.
o Specifies the port number of the receiving application.
3. Sequence Number:
o 32-bit field.
o Identifies the number of the first byte in the segment.
o During connection setup, each side generates an Initial Sequence Number (ISN).
4. Acknowledgment Number:
o 32-bit field.
o Indicates the next byte expected by the receiver.
o Example: If byte x is received, the acknowledgment number will be x+1.
5. Header Length:
o 4-bit field.
o Indicates the header size in 4-byte words.
o Values range from 5 (20 bytes) to 15 (60 bytes).
6. Control Flags:
o 6 control bits manage:
▪ Flow control.
▪ Connection establishment and termination.
▪ Data transfer modes.
7. Window Size:
o 16-bit field.
o Specifies the size of the receiver’s window (maximum: 65,535 bytes).
o Determines how much data can be sent without acknowledgment.
8. Checksum:
o 16-bit field.
o Ensures data integrity.
o Mandatory in TCP (optional in UDP).
o Uses a pseudo header for computation.
9. Urgent Pointer:
o 16-bit field (used only if urgent flag is set).
o Indicates the last urgent byte’s position by adding its value to the sequence number.
10. Options:
o Up to 40 bytes for additional functionalities.
Three-Way Handshaking:
1. Step 1: Client Sends SYN:
o The client initiates the connection by sending a segment with the SYN (synchronize) flag set.
o It chooses a random Initial Sequence Number (ISN).
o The SYN segment does not carry data but consumes one sequence number.
2. Step 2: Server Sends SYN + ACK:
o The server responds with a SYN + ACK segment:
▪ SYN: Synchronizes sequence numbers for the server.
▪ ACK: Acknowledges the client's SYN.
o The server specifies the receive window size (rwnd) for the client.
o This segment also consumes one sequence number.
3. Step 3: Client Sends ACK:
o The client completes the handshake by sending an ACK segment:
▪ Acknowledges the server's SYN + ACK.
o The ACK segment does not carry data or consume a sequence number.
17. Explain the working model of Data flow and Flow control feedback in TCP
Purpose of Flow Control:
• Maintains a balance between the rate of data production (sender) and data consumption (receiver).
Data Flow Process:
1. Forward Data Flow:
o Data travels in three steps:
1. From the sending process to the sending TCP.
2. From the sending TCP to the receiving TCP.
3. From the receiving TCP to the receiving process.
2. Feedback Flow:
o Flow control feedback travels:
1. From the receiving TCP to the sending TCP.
2. From the sending TCP to the sending process.
Key Features of TCP Flow Control:
1. Receiver-Driven:
o The receiving TCP controls how much data the sending TCP can transmit.
2. Sender Adjustment:
o The sending TCP adjusts based on the feedback (e.g., window size updates).
o If the send window is full, the sender temporarily rejects new data from the application.
Practical Implementation:
• Most TCP implementations:
o Do not involve direct feedback between the receiving process and the receiving TCP.
o Instead, the receiving process pulls data from the receiving TCP as needed.
Summary:
• TCP flow control ensures:
o The receiver isn't overwhelmed by too much data.
o Data is sent smoothly based on the receiver's capacity.
With FSM model explain Reno TCP and how it differs from NewReno TCP
1. Reno TCP:
• Introduces a new Fast Recovery state in congestion control.
• Treats time-outs and three duplicate ACKs differently:
1. Time-Out:
▪ TCP moves to the Slow Start state.
▪ Resets the congestion window (cwnd) to 1 MSS (Maximum Segment Size).
2. Three Duplicate ACKs:
▪ TCP moves to the Fast Recovery state instead of Slow Start.
▪ Behavior in Fast Recovery:
▪ cwnd is set to ssthresh + 3 MSS (higher than Tahoe's 1 MSS).
▪ cwnd grows exponentially while duplicate ACKs continue.
▪ When new ACKs (not duplicates) arrive, TCP exits Fast Recovery.
2. Key Difference Between Tahoe and Reno:
• Tahoe: Drops cwnd to 1 MSS after detecting congestion (time-out or duplicate ACKs).
• Reno: Uses Fast Recovery, setting cwnd higher (ssthresh + 3 MSS) after duplicate ACKs.
3. NewReno TCP:
• Optimization on Reno:
o Detects and handles multiple lost segments in the same congestion window.
• How It Works:
1. Upon three duplicate ACKs, retransmits the first lost segment.
2. Waits for a new ACK (not a duplicate):
▪ If the ACK acknowledges the entire window, only one segment was lost.
▪ If the ACK acknowledges up to a point but not the full window:
▪ Additional segments are likely lost.
▪ NewReno retransmits these lost segments to prevent further duplicate ACKs.
4. Key Advantage of NewReno:
• Better handling of multiple segment losses without exiting Fast Recovery prematurely.
Summary:
• Reno TCP: Improves efficiency by introducing the Fast Recovery state, avoiding aggressive resets like
Tahoe.
• NewReno TCP: Further refines congestion control by efficiently addressing multiple lost segments in a single
window.
MODULE – 05
Key Components:
1. Alice and Bob - Alice is on one end (Sky Research), and Bob is on the other (Scientific Books). - Both have
devices (laptops and servers) connected to their respective networks.
2. Routers and Connections - The routers (R1, R2, R3, etc.) are the main devices that send data across the network. -
These routers connect through point-to-point WAN links (dotted lines), forming a network that allows Alice and Bob
to communicate.
3. Switched WAN - In the middle of the network, there is a switched WAN (Wide Area Network) connecting multiple
routers (R3, R4, and R5). - This helps move the data efficiently across the national ISP (Internet Service Provider).
4. Logical Connection - The blue line labeled "Logical Connection" shows the path that data takes to travel between
Alice and Bob. - Even though the data passes through many routers and links, to Alice and Bob, it looks like a
simple, direct connection.
5. Network Layers - The diagram uses color codes to represent the different layers of communication: - Application
(top layer, blue): The software Alice and Bob use. - Transport, Network, Data-link, and Physical layers: These layers
handle how the data moves from one device to another.
2. Explain Application Layer Paradigms need for Application Layer.
Client-Server Paradigm (Traditional):
• How It Works:
o The server process provides a service and runs continuously, waiting for client processes to connect
and request services.
o The client process starts only when the client needs the service.
o One server can serve multiple clients simultaneously.
• Examples:
o Common applications: HTTP (Web browsing), FTP (File transfer), SSH (Secure shell), and Email.
• Limitations:
1. High communication load on the server.
2. Server may get overwhelmed with too many client connections.
3. Expensive to maintain powerful servers.
3. Mixed Paradigm:
• Combination of Both:
o Uses a lightweight client-server model to find peers.
o Actual services are delivered peer-to-peer once the peer is identified.
• Example:
o A central server helps locate the appropriate peer, and the peer-to-peer paradigm is used for service
delivery.
Key Takeaways:
• Client-Server: Reliable but limited by server capacity and cost.
• Peer-to-Peer: Scalable and cost-effective but challenging in terms of security.
• Mixed: Combines the benefits of both for specific use cases.
\
5. Bring out the difference Interactive communication using UDP and TCP.
6. With a neat Architecture diagram explain World Wide Web, How web browser interacts with web server
• Definition: A new TCP connection is created for each request/response. After sending the response,
the server closes the connection.
Example:
Overhead: For each item (HTML, image), a new connection is opened and closed, which slows down the
process.
Example:
Advantages: Only one connection is needed for multiple requests, reducing overhead and saving time.