One question often comes to the mind. - If the data link layer is reliable and has flow
- and error control, do we need this at the transport layer, too?
- The answer is yes. Reliability at the data link layer is between two nodes;
- we need reliability between two ends. Because the network layer in the Internet is unreliable (best-effort delivery), we need to implement reliability at the transport layer.
Error control in data link and transport layer - As we will see, flow and error control in TCP is implemented by the sliding window
- protocol,
UDP - The User Datagram Protocol (UDP) is called a connectionless, unreliable transport protocol. It does not add anything to the services of IP except to provide process-to process
- communication instead of host-to-host communication.
- Also, it performs very limited error checking.
If UDP is so powerless, why would a process want to use it? - UDP is a very simple protocol using a minimum of overhead. If a process wants to send a small message and does not care much about reliability,
- it can use UDP.
- Sending a small message by using UDP takes much less interaction between the sender and receiver than using TCP or SCT
Well Know Port No. UDP - Destination port number. This is the port number used by the process running on
- the destination host. It is also 16 bits long
- There is a field in the IP datagram
- that defines the total length. There is another field in the IP datagram that defines
- the length of the header. So if we subtract the value of the second field from the
- first, we can deduce the length of a UDP datagram that is encapsulated in an
- IP datagram.
- PROCESS-TO-PROCESS DELIVERY
- The transport layer is responsible for process-to-process delivery—the delivery of a packet, part of a message, from one process to another. Two processes communicate in a client/server relationship,
- The transport layer is responsible for process-to-process delivery.
- Figure 23.1 Types of data deliveries
- Client, server
- 1. Local host
- 2. Local process
- 3. Remote host
- 4. Remote process
- lANA Ranges
- The lANA (Internet Assigned Number Authority) has divided the port numbers into
- three ranges: well known, registered, and dynamic (or private)
- o Well-known ports.
- The ports ranging from 0 to 1023 are assigned and controlled
- by lANA. These are the well-known ports.
- Registered ports. The ports ranging from 1024 to 49,151 are not assigned or controlled
- by lANA.
- Dynamic ports. The ports ranging from 49,152 to 65,535 are neither controlled
- nor registered. They can be used by any process. These are the ephemeral ports
- Figure 23.5 Socket address
- Figure 23.6 Multiplexing and demultiplexing
- Figure 23.7 Error control
- Figure 23.8 Position of UDP, TCP, and SCTP in TCP/IP suite
- PROCESS-TO-PROCESS DELIVERY
- The transport layer is responsible for process-to-process delivery—the delivery of a packet, part of a message, from one process to another. Two processes communicate in a client/server relationship, as we will see later.
- The transport layer is responsible for process-to-process delivery.
- Figure 23.1 Types of data deliveries
- Client, server
- 1. Local host
- 2. Local process
- 3. Remote host
- 4. Remote process
- lANA Ranges
- The lANA (Internet Assigned Number Authority) has divided the port numbers into
- three ranges: well known, registered, and dynamic (or private)
- o Well-known ports.
- The ports ranging from 0 to 1023 are assigned and controlled
- by lANA. These are the well-known ports.
- Registered ports. The ports ranging from 1024 to 49,151 are not assigned or controlled
- by lANA.
- Dynamic ports. The ports ranging from 49,152 to 65,535 are neither controlled
- nor registered. They can be used by any process. These are the ephemeral ports
- Figure 23.3 IP addresses versus port numbers
- Figure 23.5 Socket address
- Figure 23.6 Multiplexing and demultiplexing
- Figure 23.7 Error control
- Figure 23.8 Position of UDP, TCP, and SCTP in TCP/IP suite
- USER DATAGRAM PROTOCOL (UDP)
- The User Datagram Protocol (UDP) is called a connectionless, unreliable transport protocol. It does not add anything to the services of IP except to provide process-to-process communication instead of host-to-host communication.
- 13 daytime
- 111 RPC
- 161 SNMP
- 53 DNS
- In UNIX, the well-known ports are stored in a file called /etc/services. Each line in this file gives the name of the server and the well-known port number. We can use the
- grep utility to extract the line corresponding to the desired application. The following shows the port for FTP. Note that FTP can use port 21 with either UDP or TCP.
- Figure 23.9 User datagram format
- UDP length = IP length – IP header’s length
- Figure 23.10 Pseudoheader for checksum calculation
- If the checksum does not include the pseudoheader, a user datagram may arrive safe
- and sound. However, if the IP header is corrupted, it may be delivered to the wrong host
- Figure 23.11 shows the checksum calculation for a very small user datagram with only 7 bytes of data. Because the number of bytes of data is odd, padding is added for checksum calculation. The pseudoheader as well as the padding will be dropped when the user datagram is delivered to IP.
- Figure 23.11 Checksum calculation of a simple UDP user datagram
- The UDP checksum calculation is different from the one for IP and ICMP. Here
- the checksum includes three sections:
- a pseudoheader,
- the UDP header,
- and the data
- coming from the application layer.
Do'stlaringiz bilan baham: |