3. INTERNETWORKING (PART 3: IP) Rocky K. C. Chang Department of Computing The Hong Kong Polytechnic University 18 February 2016 1.

Slides:



Advertisements
Similar presentations
CE363 Data Communications & Networking Chapter 7 Network Layer: Internet Protocol.
Advertisements

IPv4 - The Internet Protocol Version 4
CECS 474 Computer Network Interoperability Notes for Douglas E. Comer, Computer Networks and Internets (5 th Edition) Tracy Bradley Maples, Ph.D. Computer.
Network Layer Packet Forwarding IS250 Spring 2010
Chapter 5 The Network Layer.
EEC-484/584 Computer Networks Lecture 10 Wenbing Zhao (Part of the slides are based on Drs. Kurose & Ross ’ s slides for their Computer.
1 Internetworking Outline Best Effort Service Model Global Addressing Scheme.
Spring 2003CS 4611 Internetworking COS 461 Spring 2003.
Oct 21, 2004CS573: Network Protocols and Standards1 IP: Addressing, ARP, Routing Network Protocols and Standards Autumn
Routing Fundamentals and Subnetting
CSE331: Introduction to Networks and Security Lecture 7 Fall 2002.
Extending Networks. Three Levels of Extension Physical Layer –Repeaters Link Layer –Bridges –Switches Network –Routers: “Connecting networks”
Spring 2002CS 4611 Internetworking Outline Best Effort Service Model Global Addressing Scheme.
Shivkumar Kalyanaraman Rensselaer Polytechnic Institute 1-1 Internetworking: addressing, forwarding, resolution, fragmentation Shivkumar Kalyanaraman Rensselaer.
1 The Classic Internet Protocol (RFC 791) Dr. Rocky K. C. Chang 18 September 2006.
Chapter 19 Binding Protocol Addresses (ARP) Chapter 20 IP Datagrams and Datagram Forwarding.
Module 10. Internet Protocol (IP) is the routed protocol of the Internet. IP addressing enables packets to be routed from source to destination using.
CS 6401 Internet Protocol Outline Introduction to Internet Protocol Header and address formats ICMP Tools.
IP (Internet Protocol) –the network level protocol in the Internet. –Philosophy – minimum functionality in IP, smartness at the end system. –What does.
G64INC Introduction to Network Communications Ho Sooi Hock Internet Protocol.
TCOM 509 – Internet Protocols (TCP/IP) Lecture 03_a
13-Sep-154/598N: Computer Networks Address Translation Map IP addresses into physical addresses –destination host –next hop router Techniques –encode physical.
CISCO NETWORKING ACADEMY PROGRAM (CNAP) Routing Fundamentals & Subnets
Objectives: Chapter 5: Network/Internet Layer  How Networks are connected Network/Internet Layer Routed Protocols Routing Protocols Autonomous Systems.
Network Layer Last Update Copyright Kenneth M. Chipps Ph.D.
11 NETWORK LAYER PROTOCOLS Chapter 5 IP IPX NetBEUI AppleTalk.
10/13/2015© 2008 Raymond P. Jefferis IIILect 07 1 Internet Protocol.
Fall 2005Computer Networks20-1 Chapter 20. Network Layer Protocols: ARP, IPv4, ICMPv4, IPv6, and ICMPv ARP 20.2 IP 20.3 ICMP 20.4 IPv6.
TCOM 515 IP Routing. Syllabus Objectives IP header IP addresses, classes and subnetting Routing tables Routing decisions Directly connected routes Static.
1 IP : Internet Protocol Computer Network System Sirak Kaewjamnong.
Dr. John P. Abraham Professor UTPA
Chapter 81 Internet Protocol (IP) Our greatest glory is not in never failing, but in rising up every time we fail. - Ralph Waldo Emerson.
Internetworking Internet: A network among networks, or a network of networks Allows accommodation of multiple network technologies Universal Service Routers.
CS4550 Computer Networks II IP : internet protocol, part 2 : packet formats, routing, routing tables, ICMP read feit chapter 6.
Internetworking Internet: A network among networks, or a network of networks Allows accommodation of multiple network technologies Universal Service Routers.
CS 4396 Computer Networks Lab
Internet Protocols (chapter 18) CSE 3213 Fall 2011.
Chapter-8 Network Layer in the Internet. IP Protocol: IP V4 At network layer, internet can be viewed as a collection of sub-networks or Autonomous Systems.
1 Kyung Hee University Chapter 8 Internet Protocol (IP)
CSC 600 Internetworking with TCP/IP Unit 5: IP, IP Routing, and ICMP (ch. 7, ch. 8, ch. 9, ch. 10) Dr. Cheer-Sun Yang Spring 2001.
ICS 156: Networking Lab Magda El Zarki Professor, ICS UC, Irvine.
Internet Protocols. ICMP ICMP – Internet Control Message Protocol Each ICMP message is encapsulated in an IP packet – Treated like any other datagram,
1 Version 3.1 Module 6 Routed & Routing Protocols.
Chapter 8 Internet Protocol (IP)
1 Computer Communication & Networks Lecture 19 Network Layer: IP and Address Mapping Waleed Ejaz.
THE CLASSIC INTERNET PROTOCOL (RFC 791) Dr. Rocky K. C. Chang 20 September
1 © 2004, Cisco Systems, Inc. All rights reserved. CCNA 1 Module 10 Routing Fundamentals and Subnets.
1 Chapter 4: Internetworking (Introduction) Dr. Rocky K. C. Chang 16 March 2004.
Data Communications and Computer Networks Chapter 4 CS 3830 Lecture 19 Omar Meqdadi Department of Computer Science and Software Engineering University.
1 Chapter 4: Internetworking (Internet Protocol) Dr. Rocky K. C. Chang 16 March 2004.
Sem1 - Module 10 Routing Fundamentals and Subnets
1 Chapter 4: Internetworking (IP Routing) Dr. Rocky K. C. Chang 16 March 2004.
1 Internetworking: IP Packet Switching Reading: (except Implementation; pp )
IP Protocol CSE TCP/IP Concepts Connectionless Operation Internetworking involves connectionless operation at the level of the Internet Protocol.
Univ. of TehranIntroduction to Computer Network1 An Introduction Computer Networks An Introduction to Computer Networks University of Tehran Dept. of EE.
1 Internetworking Outline Best Effort Service Model Global Addressing Scheme.
IP: Addressing, ARP, Routing
Scaling the Network: The Internet Protocol
3. Internetworking (part 2: switched LANs)
3. Internetworking (part 3: IP)
IP - The Internet Protocol
IP : Internet Protocol Surasak Sanguanpong
Internetworking Outline Best Effort Service Model
2. Fragmentation and Reassembly
Net 323 D: Networks Protocols
IP - The Internet Protocol
Scaling the Network: The Internet Protocol
Tree Structured Internet(c. 1990)
ITIS 6167/8167: Network and Information Security
IP - The Internet Protocol
Presentation transcript:

3. INTERNETWORKING (PART 3: IP) Rocky K. C. Chang Department of Computing The Hong Kong Polytechnic University 18 February

2 1. The internetworking problem Problem: How to interconnect heterogeneous networks effectively? Three problems with interconnection at the data-link layer: Do not scale to the number of data-link technologies. Do not scale to the number of hosts (or networks). Do not have a common addressing space.

3 1. The internetworking problem S2 S1 H4 H5 H3 H2 H1 Network 2 (Ethernet) Network 1 (Ethernet) H6 Network 3 (FDDI) Network 4 (point-to-point) H7S3H8

4 1.1 A layer-three internetworking solution Use IP, XNS, IPX, etc on top of the networks. Replace LAN switches with layer-three switches, more commonly known as routers. Add IP software to each end host (with the whole protocol suite software). Assign an IP address to each network interface.

5 1.1 A layer-three internetworking solution R2 R1 H4 H5 H3 H2 H1 Network 2 (Ethernet) Network 1 (Ethernet) H6 Network 3 (FDDI) Network 4 (point-to-point) H7R3H8

6 2. Encapsulation and address binding To transmit IP datagrams over any data-link network, two requirements are needed: A standard way to encapsulate IP datagrams Address resolution between IP addresses and MAC addresses Standard RFCs for specifying datagram encap-sulations and possibly address resolutions, e.g., Ethernet (RFC 894), IEEE 802 (RFC 1042), etc. A shared medium uses an Address Resolution Protocol (ARP) for address binding.

7 2.1 Data encapsulation You have seen from chapter 2 IP over DIX Ethernet IP over IEEE IP over PPP Others are in the RFC documents

8 2.2 Address resolution protocol An ARP request message is data-link broadcasted on the LAN with the target IP address. Every IP host picks up a copy of the message and examine the target IP address. If matching its IP address, send an ARP reply message back to the sender with its MAC address. Else, drop the message. To reduce broadcast traffic, each host uses an ARP cache to remember the recent binding.

9 2.2 Address resolution protocol TargetHardwareAddr (bytes 2–5) TargetProtocolAddr (bytes 0–3) SourceProtocolAddr (bytes 2–3) Hardware type = 1ProtocolType = 0x0800 SourceHardwareAddr (bytes 4–5) TargetHardwareAddr (bytes 0–1) SourceProtocolAddr (bytes 0–1) HLen = 48PLen = 32Operation SourceHardwareAddr (bytes 0–3)

An internetworking example On each “hop or link,” both data encapsulation and address resolution occur. R1 ETH FDDI IP ETH TCP R2 FDDI PPP IP R3 PPP ETH IP H1 IP ETH TCP H8

11 3. The IP service model The IP service model consists of an addressing scheme to identify an IP host, and a datagram (connectionless) model of data delivery. IP provides a best-effort service. IP makes its best effort to send a datagram to its destination. The best-effort service does not guarantee reliable datagram delivery, i.e., an unreliable service.

Internet protocol suite (incomplete) … FTPHTTPNV TFTP TCP UDP IP NET 1 2 n Application Transport Network Data-link ICMP IGMP ARP & RARP Ping DNS RTP SSL

13 4. IP datagram VersionHLen TOSLength IdentFlagsOffset TTLProtocolChecksum SourceAddr DestinationAddr Options (variable) Pad (variable) Data

14 4. IP datagram Version: 4 for the current IP. Type of service (TOS) for specifying how a router should handle this datagram. Header length handles a variable-length header. 20-byte IP header without IP options A 16-bit length limits the size of an IP datagram to 65,535 bytes, including the IP header. Identification, flags, and offset are used for packet fragmentation and reassembly.

15 4. IP datagram Time to live (TTL) limits the the number of times that a datagram processed by routers. Protocol specifies the type of payload, e.g., 6 for TCP and 17 for UDP. Checksum is a 16-bit word checksum. IP options, e.g., Source routing Record route

16 5. MTU and packet fragmentation Each network chooses a maximum packet size that can be sent on it, Maximum Transmission Unit (MTU). For example, 1500 bytes for 10-Mbps Ethernet 4352 bytes for FDDI bytes for 16-Mbps token ring Note that all MTUs are smaller than IP datagram’s maximum size. One internetworking problem is to accommodate various MTU values.

17 5. MTU and packet fragmentation To send datagrams to a directly attached host, use the network’s MTU. To send datagrams to a nondirectly attached host, use the path MTU. Path MTU is the minimum of the networks’ MTUs on the path from the source to destination. If the actual MTU used is larger than the path MTU, packet fragmentation occurs. Fragmentation occurs when a router attempts to forward it to a network with a smaller MTU.

18 5. MTU and packet fragmentation H1R1R2R3H8 ETHIP(1400)FDDIIP(1400)PPPIP(512) PPPIP(376) PPPIP(512) ETHIP(512) ETHIP(376) ETHIP(512)

19 Ident = xOffset = 0 Start of header 0 Rest of header 1400 data bytes (a) Ident = xOffset = 0 Start of header 1 Rest of header 512 data bytes (b) Ident = xOffset = 512 Start of header 1 Rest of header 512 data bytes Ident = xOffset = 1024 Start of header 0 Rest of header 376 data bytes

20 5. MTU and packet fragmentation Each IP fragment contains enough information for forwarding to the destination. A fragmented IP datagram will be reassembled only at the destination node. If any fragments do not arrive within a certain time, other received fragments in the datagram will be discarded. Fragmentation could occur multiple times to an IP datagram.

21 6. IP subnets IP subnets introduce additional levels within an IP network: A network address, a subnet ID, and a host ID. IP subnets offer flexibility in allocating addresses to different sizes of sub-networks. A subnet mask is used to indicate which bits are referred to the network and subnet ID. Each network interface stores subnet mask and its unicast IP address.

22 6. IP subnets Subnetting for a class B address: Network numberHost number Class B address Subnet mask ( ) Subnetted address Network numberHost IDSubnet ID

23 6. IP subnets Subnet mask: Subnet number: H1 R Subnet mask: Subnet number: R2 H Subnet mask: Subnet number: H3

24 7. IP forwarding mechanisms Assume that both routers and hosts already have appropriate routing tables in place. Routing tables for routers are constructed from routing protocols. Routing tables for hosts are constructed from other means. Problem: Given a routing table, how do hosts and routers forward datagrams?

Examples of routing tables For example, R1’s routing table: Network/SubnetSubnet MaskNext Hop upper int lower int For example, H1’s routing table: Network/SubnetSubnet MaskNext Hop upper int

Host’s forwarding mechanisms A host sends a datagram to another host on the same LAN or not. In the former, it sends the datagram to the destination directly. In the latter, it sends the datagram to a default router. In both cases, the host uses ARP cache or ARP to find out the corresponding MAC addresses.

A general forwarding mechanism

Characteristics of IP forwarding Both hosts and routers are involved in forwarding. Compared with routers, a host makes a much simpler binary decision. IP forwarding is done on a hop-by-hop basis. It is assumed that the next-hop router is really closer to the destination. IP forwarding is able to specify a route to a network, and not have to specify a route to every host.

29 8. The routing problem Problem: How does a router construct its routing table for IP forwarding? Forwarding vs routing Routing is the process by which forwarding tables are built. Forwarding table vs routing table A routing table is built by routing protocols as a precursor to building the forwarding table. A forwarding table consists of detail enough information to speed up datagram forwarding.

Internet topology Backbone service provider Peering point Peering point Large corporation Small corporation “ Consumer ” ISP “Consumer” ISP “ Consumer” ISP

Internet topology Major components in the Internet topology: Autonomous system (AS), e.g., polyu.edu.hk, ibm.com, etc. Internet service providers (ISPs): Local ISPs, regional ISPs, National ISPs, Backbone ISPs. Exchange networks: For local traffic interchange, e.g., HKIX. Some special networks, like Harnet in Hong Kong. Routers (plus other networks) are usually used to connect these components together.

Not all routers are equal Interior routers: Only know how to route datagrams to destinations within the same AS. Border routers: Interface between its AS and other AS: A nonbackbone router usually has a “default route” to another “more knowledgeable” router for “unknown destinations.” A backbone router is supposed to know every IP network in the Internet. Intradomain routing vs Interdomain routing

Distance vector routing protocols Each node does two things: It constructs a one-dimensional array (a vector) containing the “distances” (costs) to all other nodes. It distributes the vector to its immediate neighbors. Each node’s vector initially consists of a distance of 0 for reaching itself, and a distance of infinity for reaching other nodes. When the algorithm converges, each node knows for each destination node (1) the next node closer to the destination, and (2) the associated cost for this path.

An example

An example Node A’s routing table (using hop count as the cost)

Dynamic routing Each node periodically sends its distance vector to its neighbor (periodic updates). If link A-C fails, The cost in A’s entry to C becomes infinity. B will advertise to A a path to C with cost 1. F will advertise to A a path to C with cost 2. Therefore, A’ entry to C is updated to: Next hop = B and cost = 2.

Dynamic routing Each node may send an updated distance vector to its neighbor, triggered by external events (triggered updates). If link A-C fails, The cost in A’s entry to C becomes infinity. A will immediately send its updated vector to B, E, F. This update does not affect B’s routing table. However, E will update its entry to C from 2 to infinity, and then from infinity to 3; and similarly for F.

Routing loops If the link A-E fails, The corresponding entry in A is updated. A triggered update from A, and periodic updates from B, C, and F. Possible timing (>: earlier than): Case 1: A > B and A > C and A > F Case 2: A > B and A > C but A < F Case 3: A > B and A > F, but A < C In case 1, all nodes will eventually conclude that E is unreachable. In case 2, a routing loop between A and F forms.

Routing loops In case 3, a routing loop between A and C forms. In both cases 2 and 3, the cost to E keeps on increasing. One solution to this problem is to declare the link unusable when the cost reaches, say, 16 (count to infinity). Split horizon is another solution to solving 2-node routing loop. A node will not advertise a route back to another node that serves as the next hop for that route. For example, B, C, F will not advertise their routes to E back to A.

Routing information protocol (RIP) RIP implements the distance vector approach. A hop count of 16 is interpreted as infinity. Each RIP router broadcasts its distance vectors to its neighbors every 30 seconds. RIP is implemented at the application level. Common daemons used on the Unix systems are the programs routed and gated. RIP packets are carried over UDP and IP.

Link state routing protocols In this approach, every nodes maintains the network topology information in a link state database. Thus, this approach relies on two mechanisms: A reliable flooding for dissemination of link-state information, and a shortest-path algorithm for computing routes.

An example

An example Link state database:

Link state updates The link state can be based on any metric, including hop count, latency, throughput, monetary cost, etc. When a link state is changed, say from 1 to 2 for A  E, A will send this update to all other nodes through a reliable flooding scheme. A sends the update to B, C, F. A ensures the reliable transmission of the update through positive acknowledgment and retransmission.

Link state updates B, C, F, upon receiving the update, compare the sequence number of the update and that in their databases. If the sequence number in the update is higher, update the link state in the database, and forward it to other interfaces other than the one where the update is received. Otherwise, drop the update and no change in the database. Although C receives two copies of the update, it forwards only one copy to D and the other is discarded. The new link state database becomes

Link state updates

Computing optimal paths Given a link state database for the network topology, each node can apply any shortest-path algorithms to find optimal paths from itself to other nodes in the network. For example, using the hop count as the metric, we have for node A:

Computing optimal paths A B E FG C D

Open shortest path first (OSPF) protocol OSPF implements a link state approach. OSPF supports different type-of-service routing by having different sets of metric for route computation. OSPF supports equal-cost routes to a destination. OSPF reduces the amount of routing update messages as compared with RIP. OSPF provides fast and loopless convergence.