PART-03
Internet and Protocol
Covered lectures
• What is internet? (Lecture-1)
• Infrastructure (Lecture-1)
• IP address (Lecture-2)
• Protocol Stacks and Packets (Lecture-2)
• Internet Routing Hierarchy (Lecture-2)
• Application Protocols: HTTP and the World Wide Web (Lecture-3)
• TCP/IP (Lecture-3)
• UDP(Lecture-3)
                                                                   2
Application Protocols
An application layer protocol defines how application processes
(clients and servers), running on different end systems, pass
messages to each other. In particular, an application layer protocol
defines:
• The types of messages, e.g., request messages and response
  messages.
• The syntax of the various message types, i.e., the fields in the
  message and how the fields are delineated.
• The semantics of the fields, i.e., the meaning of the information
  that the field is supposed to contain;
• Rules for determining when and how a process sends messages
  and responds to messages.
                                                                   3
4
    TCP/IP
The OSI Model we just looked at is just a
reference/logical model.
                                            5
TCP Header
             6
Network Access Layer –
• This layer corresponds to the combination of Data Link Layer and
  Physical Layer of the OSI model. It looks out for hardware addressing
  and the protocols present in this layer allows for the physical
  transmission of data.
                                                                      7
Internet Layer –
• This layer parallels the functions of OSI’s Network layer. It defines the protocols
  which are responsible for logical transmission of data over the entire network.
  The main protocols residing at this layer are :
1.IP – stands for Internet Protocol and it is responsible for delivering packets from
  the source host to the destination host by looking at the IP addresses in the
  packet            headers.          IP           has            2          versions:
  IPv4 and IPv6. IPv4 is the one that most of the websites are using currently. But
  IPv6 is growing as the number of IPv4 addresses are limited in number when
  compared to the number of users.
2.ICMP – stands for Internet Control Message Protocol. It is encapsulated within IP
  datagrams and is responsible for providing hosts with information about network
  problems.
3.ARP – stands for Address Resolution Protocol. Its job is to find the hardware
  address of a host from a known IP address. ARP has several types: Reverse ARP,
  Proxy ARP, Gratuitous ARP and Inverse ARP.
                                                                                     8
Host-to-Host Layer –
• This layer is analogous to the transport layer of the OSI model. It is
  responsible for end-to-end communication and error-free delivery of data. It
  shields the upper-layer applications from the complexities of data. The two
  main protocols present in this layer are :
• Transmission Control Protocol (TCP) – It is known to provide reliable and error-
  free communication between end systems. It performs sequencing and
  segmentation of data. It also has acknowledgment feature and controls the
  flow of the data through flow control mechanism. It is a very effective protocol
  but has a lot of overhead due to such features. Increased overhead leads to
  increased cost.
• User Datagram Protocol (UDP) – On the other hand does not provide any such
  features. It is the go-to protocol if your application does not require reliable
  transport as it is very cost-effective. Unlike TCP, which is connection-oriented
  protocol, UDP is connectionless.
                                                                                 9
4. Application Layer –
• This layer performs the functions of top three layers of the OSI model: Application, Presentation and
  Session Layer. It is responsible for node-to-node communication and controls user-interface
  specifications. Some of the protocols present in this layer are: HTTP, HTTPS, FTP, TFTP, Telnet, SSH,
  SMTP, SNMP, NTP, DNS, DHCP, NFS, X Window, LPD. Have a look at Protocols in Application Layer for
  some information about these protocols. Protocols other than those present in the linked article are :
• HTTP and HTTPS – HTTP stands for Hypertext transfer protocol. It is used by the World Wide Web to
  manage communications between web browsers and servers. HTTPS stands for HTTP-Secure. It is a
  combination of HTTP with SSL(Secure Socket Layer). It is efficient in cases where the browser need
  to fill out forms, sign in, authenticate and carry out bank transactions.
• SSH – SSH stands for Secure Shell. It is a terminal emulations software similar to Telnet. The reason
  SSH is more preferred is because of its ability to maintain the encrypted connection. It sets up a
  secure session over a TCP/IP connection.
• NTP – NTP stands for Network Time Protocol. It is used to synchronize the clocks on our computer to
  one standard time source. It is very useful in situations like bank transactions. Assume the following
  situation without the presence of NTP. Suppose you carry out a transaction, where your computer
  reads the time at 2:30 PM while the server records it at 2:28 PM. The server can crash very badly if
  it’s out of sync.
                                                                                                       10
DNS
 https://www.cloudflare.com/learning/dns/what-is-dns/
                                                        11
UDP
• User Datagram Protocol (UDP) is a communications protocol that is
  primarily used to establish low-latency and loss-tolerating
  connections between applications on the internet.
                                                                 12
Applications of UDP:
• Used for simple request-response communication when the size of data is
  less and hence there is lesser concern about flow and error control.
• It is a suitable protocol for multicasting as UDP supports packet switching.
• UDP is used for some routing update protocols like RIP(Routing Information
  Protocol).
• Normally used for real-time applications which can not tolerate uneven delays
  between sections of a received message.
• Following implementations uses UDP as a transport layer protocol:
   •   NTP (Network Time Protocol)
   •   DNS (Domain Name Service)
   •   BOOTP, DHCP.
   •   NNP (Network News Protocol)
   •   Quote of the day protocol
   •   TFTP, RTSP, RIP.
                                                                                 13
Applications of UDP:
• The application layer can do some of the tasks through UDP-
   • Trace Route
   • Record Route
   • Timestamp
• UDP takes a datagram from Network Layer, attaches its header,
  and sends it to the user. So, it works fast.
• Actually, UDP is a null protocol if you remove the checksum field.
   • Reduce the requirement of computer resources.
   • When using the Multicast or Broadcast to transfer.
   • The transmission of Real-time packets, mainly in multimedia applications.
                                                                             14
Overall Findings
                   15
HTTP and the World Wide Web
                              16