Download presentation
Presentation is loading. Please wait.
1
Networking Theory (part 2)
2
Internet Architecture
The Internet is a worldwide collection of smaller networks that share a common suite of communication protocols (TCP/IP). It is an open system, built on common network, transport and application layer protocols, while granting the flexibility to connect a variety of computers, devices and operating systems to it.
3
Design of the Internet The Internet is the result of many decades of innovation and experimentation. The TCP/IP protocols have been carefully designed, tested and improved over the years.
4
Design of the Internet Major design goals:
Resource sharing between networks Hardware and software independence Reliability and robustness Fault tolerant protocols - data could be rerouted depending on the state of the network "Good" protocols that are efficient and simple.
5
TCP/IP Protocol Suite Major protocols: Internet Protocol (IP)
Internet Control Message Protocol (ICMP) Transmission Control Protocol (TCP) User Datagram Protocol (UDP)
6
Internet Protocol (IP)
IP is a Layer 3 protocol (network layer) It is used to transmit data packets over the Internet It is the most widely used networking protocol in the world. IP acts as a bridge between networks of different types
7
Internet Protocol (IP)
IP is a packet-switching network protocol. Information is exchanged between two hosts in the form of IP packets (IP datagrams). Each datagram is treated as a discrete unit - there are no "connections" between machines at the network layer. Connection services are provided by the higher-level protocols at the transport layer.
8
Internet Protocol (IP)
The IP datagram consists of a header and the actual data being sent. The header contains essential information for controlling how it will be delivered.
9
IPV4 datagram format
10
Internet Protocol (IP)
Although each machine has its own physical address, each host machine under the Internet Protocol must be assigned a unique IP address. The IP address is a four-byte (32-bit) address. Example: The IP address is not bound to a particular physical machine. Network programming in Java does not require the use of the physical address; only the IP address is used.
11
Internet Protocol (IP)
Humans do not find IP addresses easy to remember. An addressing scheme is also used which allows the use of textual names (hostnames) instead of numerical values. Example: java.sun.com
12
Internet Control Message Protocol (ICMP)
The Internet Protocol provides absolutely no guarantee of datagram delivery. The Internet Control Message Protocol (ICMP) is a mechanism for error-control. It is used in conjunction with the Internet Protocol to report errors when and if they occur.
13
Internet Control Message Protocol (ICMP)
The relationship between IP and ICMP is a strong one. E.g: IP uses ICMP if it needs to notify another host of an error. ICMP requires IP to send the error message. Note that a host cannot rely solely on ICMP to guarantee delivery as there is no guarantee that ICMP messages will be sent or that they will reach their intended destination.
14
Internet Control Message Protocol (ICMP)
Five error messages are defined: Destination Unreachable If a gateway is unable to pass a datagram on to its destination, this message is sent back to the original host. Parameter Problem This message is sent to the sending host if a gateway is unable to process the header parameters of an IP datagram.
15
Internet Control Message Protocol (ICMP)
Redirect If a shorter path, or alternate route, is available, a gateway may send this message to the router that passed on a datagram Source Quench This message may be sent in an attempt to reduce the number of incoming datagrams when a router, gateway or host becomes overloaded. Time Exceeded Whenever the TTL value of a datagram reaches zero is discarded. This message may be sent if this event occurs.
16
Internet Control Message Protocol (ICMP)
ICMP supports several informational messages such as: Echo Request/Echo Reply Used to determine whether a host is alive and can be reached. Address Mask Request/Address Mask Reply Provides the functionality to determine the address mask which controls which bits of an IP address correspond to a host, and which bits determine the network/subnet portion.
17
Transmission Control Protocol (TCP)
TCP is a Layer 4 protocol (transport layer) that provides guaranteed delivery and ordering of bytes. TCP uses IP to send TCP segments, which contain additional information that allows it to order packets and resend them if they go astray.
18
Transmission Control Protocol (TCP)
TCP uses communication ports to distinguish one application or service from another. A host machine can have many applications connected to one or more ports. Although TCP provides a simpler programming interface, it may reduce network performance.
19
User Datagram Protocol (UDP)
UDP is a Layer 4 protocol (transport layer) that applications can use to send packets of data across the Internet (as opposed to TCP, which sends a sequence of bytes). UDP also supports communication ports. UDP does not guarantee delivery packets. It also does not guarantee that they will arrive in the right order. Although unreliable, UDP offers faster communication.
20
Internet Application Protocols
Network programmers are more interested in the protocols at the application layer. Examples: Protocols for accessing and sending Protocols for transferring files Protocols for reading Web pages
21
File Transfer Protocol (FTP)
Telnet A service that allows users to open a remote-terminal session to a specific machine. Uses TCP port 23. File Transfer Protocol (FTP) Allows file transfers Uses TCP port 21 (to control sessions) and TCP port 20 (for the actual transfer). Post Office Protocol version 3 (POP3) Used to access Allows users to read mail offline. Uses TCP port 110.
22
Internet Message Access Protocol (IMAP)
Less popular than POP3 as it requires continual connection to the mail server. Message are stored on a server and not on the user's system. Uses port 143. Simple Mail Transfer Protocol (SMTP) Allows messages to be delivered over the Internet. Uses port 25.
23
HyperText Transfer Protocol (HTTP)
One of the most popular protocols in use on the Internet; it made the World Wide Web possible. Java provides good HTTP support. Uses TCP port 80.
24
TCP/IP Protocol Suite Layers
Although there are seven OSI network layers, not all are used in Internet programming. The layers beneath the network layer are encapsulated from the network programmer.
25
TCP/IP Protocol Suite Layers
HTTP SMTP FTP POP3 TCP UDP ICMP Internet Protocol TCP/IP Stack
26
TCP/IP Protocol Suite Layers
POP3 command: RETR1 Application layer TCP segment: TCP header RETR1 Transport layer IP datagram: IP header TCP header RETR1 Network layer Modem frame: Data link layer Modem header IP header TCP header RETR1 Carrier wave: Physical layer
27
Security Issues: Firewalls and Proxy Servers
Firewall: while being an excellent tool for n/w admin often is a developer’s worst enemy It blocks direct UDP and TCP access, making application that uses these protocols practically unusable Need to adapt software to proxy requests using protocol such as HTTP Direct UDP/TCP communication is simpler and offers better performance Using proxy server and HTTP can add delays
28
Proxy Server It is a machine that acts as a proxy for application protocols The server accepts incoming connections from machines within a local n/w and makes requests on their behalf to machines connected to the Internet Advantages: Direct access to internal machines is never established
29
Proxy Server Only popular protocols such as HTTP is permitted access while newer application such as games or RealAudio is not permitted Most proxy servers also log networking events to allow n/w admin to track unusual communications and their origin
Similar presentations
© 2025 SlidePlayer.com. Inc.
All rights reserved.