20. Switched Local Area Networks

Slides:



Advertisements
Similar presentations
5: DataLink Layer5-1 Chapter 5 Link Layer and LANs A note on the use of these ppt slides: Were making these slides freely available to all (faculty, students,
Advertisements

Chapter 5 Link Layer Computer Networking: A Top Down Approach 6 th edition Jim Kurose, Keith Ross Addison-Wesley March 2012 A note on the use of these.
Chapter 5 Link Layer Computer Networking: A Top Down Approach 6 th edition Jim Kurose, Keith Ross Addison-Wesley March 2012 A note on the use of these.
CPSC Network Layer4-1 IP addresses: how to get one? Q: How does a host get IP address? r hard-coded by system admin in a file m Windows: control-panel->network->configuration-
Internet Control Protocols Savera Tanwir. Internet Control Protocols ICMP ARP RARP DHCP.
Network Layer introduction 4.2 virtual circuit and datagram networks 4.3 what’s inside a router 4.4 IP: Internet Protocol  datagram format  IPv4.
Network Layer4-1 Network layer r transport segment from sending to receiving host r on sending side encapsulates segments into datagrams r on rcving side,
Everything. MACIP End-host IP: MAC: 11:11:11:11:11 gateway IP: MAC: 22:22:22:22:22 Google server IP: MACIP MACInterfaceMACInterface.
Lecture 8 Modeling & Simulation of Communication Networks.
Chapter 5 Link Layer Computer Networking: A Top Down Approach 6 th edition Jim Kurose, Keith Ross Addison-Wesley March 2012 Link Layer data center.
Network Layer4-1 NAT: Network Address Translation local network (e.g., home network) /24 rest of.
DHCP: Dynamic Host Configuration Protocol
Chapter 5 Link Layer and LANs
Chapter 4: Managing LAN Traffic
Adapted from: Computer Networking, Kurose/Ross 1DT066 Distributed Information Systems Chapter 4 Network Layer.
A day in the life: scenario
Router and Routing Basics
Link Layer 5-1 Link layer, LAN s: outline 5.1 introduction, services 5.2 error detection, correction 5.3 multiple access protocols 5.4 LANs  addressing,
1 John Magee 11 July 2013 CS 101 Lecture 11: How do you “visit” a web page, revisted Slides adapted from Kurose and Ross, Computer Networking 5/e Source.
Transport Layer 3-1 Chapter 4 Network Layer Computer Networking: A Top Down Approach 6 th edition Jim Kurose, Keith Ross Addison-Wesley March 2012  CPSC.
NUS.SOC.CS2105 Ooi Wei Tsang Application Transport Network Link Physical you are here.
1 Chapter 4: Network Layer r 4.4 IP: Internet Protocol m Datagram format m IPv4 addressing m ICMP m IPv6 r 4.5 Routing algorithms m Hierarchical routing.
5: Link Layer Part Link Layer r 5.1 Introduction and services r 5.2 Error detection and correction r 5.3Multiple access protocols r 5.4 Link-Layer.
Link Layer5-1 Synthesis: a day in the life of a web request  journey down protocol stack complete!  application, transport, network, link  putting-it-all-together:
CSCI 3335: C OMPUTER N ETWORKS A DAY IN THE LIFE OF A WEB REQUEST Vamsi Paruchuri University of Central Arkansas
Transport Layer3-1 Chapter 4: Network Layer r 4. 1 Introduction r 4.2 Virtual circuit and datagram networks r 4.3 What’s inside a router r 4.4 IP: Internet.
Link Layer5-1 Synthesis: a “day” in the life of a web request  journey down protocol stack!  application, transport, network, link  putting-it-all-together:
Chapter 5 Link Layer Computer Networking: A Top Down Approach 6 th edition Jim Kurose, Keith Ross Addison-Wesley March 2012 A note on the use of these.
Multiple Protocol Support: Multiprotocol Level Switching.
Data Communications and Computer Networks Chapter 4 CS 3830 Lecture 19 Omar Meqdadi Department of Computer Science and Software Engineering University.
5: DataLink Layer5-1 Virtualization of networks Virtualization of resources: powerful abstraction in systems engineering: r computing examples: virtual.
Chapter 7 Application Layer 1 Some of the slides in this chapter are courtesy of Profs. Kurose/Ross and others.
End-host IP: MAC: 11:11:11:11:11 gateway IP: MAC: 22:22:22:22:22 Google server IP: interne t interface DNS server IP:
Multi-protocol Label Switching (MPLS) RFC 3031 MPLS provides new capabilities: QoS support Traffic engineering VPN Multiprotocol support.
Chapter 5 Link Layer Computer Networking: A Top Down Approach 6 th edition Jim Kurose, Keith Ross Addison-Wesley March 2012 A note on the use of these.
Chapter 5 Link Layer Computer Networking: A Top Down Approach 6 th edition Jim Kurose, Keith Ross Addison-Wesley March 2012 A note on the use of these.
1 Computer Networks Chapter 5. Network layer The network layer is concerned with getting packets from the source all the way to the destination. Getting.
Introduction to Networks
Chapter 5 Link Layer A note on the use of these ppt slides:
Virtualization of networks
Chapter 4: Network Layer
Link Layer 5.1 Introduction and services
Announcement Written Homework Assignment 2: Due Fri. November 18, 11:59pm Programming Assignment 3: Due Mon. Nov ember 14, 11:59pm Group of three students.
Routing Jennifer Rexford.
A Typical Connection Scenario
EE 122: Lecture 19 (Asynchronous Transfer Mode - ATM)
CS 280: Summary: A day in the life of a web request
Course Review 2015 Computer networks 赵振刚
MAC Addresses and ARP 32-bit IP address:
Chapter 4 Data Link Layer Switching
Network Data Plane Part 3
Virtual LANs.
Lecture 9 Ethernet and other Link Layer protocols
Link layer, LANs: outline
CS 457 – Lecture 10 Internetworking and IP
What’s “Inside” a Router?
Introduction to Networks
ECE 4450:427/527 - Computer Networks Spring 2017
Chapter 6 The Data Link layer
Wide Area Networks and Internet CT1403
NTHU CS5421 Cloud Computing
Course on Computer Communication and Networks Lecture 16 Synthesis, Summary/flashback and Projection (related topics – continuation of study) EDA344/DIT.
Chapters 1~5 Overview Computer Networking: A Top Down Approach 6th edition Jim Kurose, Keith Ross Addison-Wesley Prof. Hong Liu for ECE369 Adapted from.
Chapter 4 Network Layer Computer Networking: A Top Down Approach 5th edition. Jim Kurose, Keith Ross Addison-Wesley, April Network Layer.
1 Multi-Protocol Label Switching (MPLS). 2 MPLS Overview A forwarding scheme designed to speed up IP packet forwarding (RFC 3031) Idea: use a fixed length.
Chapter 6 The Link Layer and LANs
CMPE 252A : Computer Networks
Synthesis A day in the life of a web request
Chapter 5: Link Layer 5.1 Introduction and services
Chapter 4: outline 4.1 Overview of Network layer data plane
Presentation transcript:

20. Switched Local Area Networks Addressing in LANs (ARP) Spanning tree algorithm Forwarding in switched Ethernet LANs Virtual LANs Layer 3 switching Datacenter networks Roch Guerin (with adaptations from Jon Turner and John DeHart, and material from Kurose and Ross)

Virtual LANs (VLAN) Allows hosts to be divided among different VLANs C D E A F B id=3 id=7 Allows hosts to be divided among different VLANs Ethernet packets do not propagate beyond VLAN boundaries to go between VLANs, packet must pass through a router but many switches support router-like functions that handle this VLANs often correspond to IP subnets, but need not VLANs can increase network’s traffic capacity Packet’s VLAN is identified by VLAN id carried in packet 12 bit VLAN “tag” inserted just before the “ethertype” field packets with VLAN id X are sent only on ports that belong to X “host ports” typically belong to one VLAN VLAN tag is typically added/removed by switches at “host ports” routers and servers often participate in multiple VLANs in this case, “endpoint” adds the VLAN tag

Ethernet Frame With VLAN Tag Tag starts with two-byte value x8100 takes place of type field, allowing packet to be identified as tagged packet Priority field (3 bits) 0 for best-effort, 7 for highest priority Drop Eligible Bit indicates packet that can be preferentially discarded during congestion VLAN Identifier (12 bits) value of 0 means “no vlan” Double tagging a vlan tag that starts with 0x9100, identifies the first in a pair of tags allows ISPs to use VLAN tags while carrying “customer-tagged” packets preamble (7 bytes) start of frame destination address source address x8100 pri d vlan id type (2 bytes) data (46-1500 bytes) CRC

VLANs and Overlay Networks “overlay” links VLANs can be used to implement virtual links joining routers configured by network managers can be “provisioned” to provide guaranteed bandwidth support for “private WANs” Routers treat these much like physical links link rates can be configured so several overlay links can share physical links – no constraint on individual link rates and several overlay links can share a single router port makes it easy to add new links between routers, as needed overlay link rates can be changed in response to traffic may require re-routing of some overlay links effectively replaces router ports with cheaper switch ports Ethernet switches VLAN paths

Some New-ish Developments Faster STP response to topology changes original protocol can take nearly a minute to converge on new spanning tree after a link fails Rapid Spanning Tree Protocol cuts time to under 10 seconds Computing multiple spanning trees when VLANs were first introduced, all VLANs used the same spanning tree manual configuration required to use all available links Multiple Spanning Tree Protocol allows automatic configuration of multiple subtrees (that is, may restrict a tree to a region) VLANs are mapped to trees (so several VLANs may share a tree) Shortest Path Bridging (standardized in 2012) link-state protocol (based on IS-IS) switches distribute topology information, compute shortest-path-trees and configure local routing tables Utilizes more of the network paths than STP allowed

MPLS MPLS header edge router core router Multiprotocol Label Switching extends IP to provide “virtual links” within IP networks MPLS-only switches are potentially less expensive than routers MPLS features often added to standard routers allows finer-grained management of traffic than IP routing alone MPLS headers added by “edge routers” (before IP header) Core routers switch packets using “labels” in MPLS headers labels used to select entries in MPLS routing tables packets may contain multiple “stacked” headers routing table entries can be configured to select output based on label, replace label value with another, push/pop headers

Base MPLS Label Distribution Relies on fact that all routers in a domain share the same routing table Routers distribute labels together with route entries Bandwidth can be included in modified routing protocols IP packets are “pre-pended” with corresponding label by ingress routers Routers swap labels at each hop based on downstream mapping Egress router removes label before forwarding the IP packet R6 D R4 R5 modified link state flooding A

Base MPLS Label Distribution Src In label Out label Dest Out iface R6 10 A 12 D R5 8 1 In label Out label Dest Out iface 10 6 A 1 12 9 D R6 D 1 1 R4 R3 R5 A R2 In label Out label Dest Out iface 8 6 A In label Out label Dest Out iface 6 - A

Base MPLS Label Distribution Src In label Out label Dest Out iface R6 10 A 12 D R5 8 1 In label Out label Dest Out iface 10 6 A 1 12 9 D DA=A DA=A R6 L=8,DA=A L=10,DA=A D 1 1 R4 R3 L=6,DA=A R5 DA=A DA=A A R2 In label Out label Dest Out iface 8 6 A In label Out label Dest Out iface 6 - A

Base MPLS Label Distribution Relies on fact that all routers in a domain share the same routing table Routers distribute labels together with route entries IP packets are “pre-pended” with corresponding label by ingress routers Routers swap labels at each hop based on downstream mapping Egress router removes label before forwarding the IP packet <L2,R1> <L6,R1> <L5,R1> <L2,R1> <L6,R1> <L4,R1> <L6,R1> <L2,R1> <L4,R1> <L2,R1> <L4,R1> R1:158.130.0.0/16

Base MPLS Packet Forwarding Packet to: 158.130.14.67 Relies on fact that all routers in a domain share the same routing table Routers distribute labels together with route entries IP packets are “pre-pended” with corresponding label by ingress routers Routers swap labels at each hop based on downstream mapping Egress router removes label before forwarding the IP packet <L2, 158.130.14.67> <L6, 158.130.14.67> <L4, 158.130.14.67> <L2, 158.130.14.67> <L6, 158.130.14.67> <L4, 158.130.14.67> <L2, 158.130.14.67> <L6, 158.130.14.67> <L4, 158.130.14.67> <L2, 158.130.14.67> <L4, 158.130.14.67> <158.130.14.67>

Explicit Routing Packets to: 158.130.0.0/16 Overcome the shortest path, destination-based constraint of standard IP forwarding Greater flexibility and control in distributing traffic across links R1 R2 R3 IP Forwarding <158.130.14.67>

Explicit Routing Packets to: 158.130.0.0/16 Overcome the shortest path, destination-based constraint of standard IP forwarding Greater flexibility and control in distributing traffic across links R1 R2 R3 From R2 From R1 From R3 MPLS Forwarding <158.130.14.67>

Layer 3 Switching Many switches have extensive support for IP routing routing features first added to connect subnets in different VLANs feature sets have expanded as way to “add value” to products Example features IP forwarding, ARP, ICMP, DHCP, RIP, ... Diffserv QoS with 8 queues per link IGMP support (snooping and querier functions) Access Control lists (firewall functions) Getting harder to distinguish routers and switches routers support different kinds of layer 2 links (not just Ethernet) and support multiple L3 protocols (not just IP) routers have more extensive feature sets, more configurable routers have larger routing tables & buffers, flexible queueing switches generally less expensive

Inside a 40-ft Microsoft container, Data Center Networks 10’s to 100’s of thousands of hosts, often closely coupled, in close proximity: e-business (e.g., Amazon) content-servers (e.g., YouTube, Akamai, Apple, Microsoft) search engines, data mining (e.g., Google) Challenges multiple applications, each serving many clients managing/balancing load multiple “tenants” must keep tenants isolated actions of one tenant must not interfere with another Inside a 40-ft Microsoft container, Chicago data center

Scaling Up ... Example Networking challenges . . . servers Top-Of-Rack switch ... pod switch . . . pod backbone switch Example Each rack has 32 servers each with 32 cores TOR switch with 10G and/or 40G links 32 rack pod has 1024 servers, and 32K cores 64 pod configuration has 32K servers, 1M cores Networking challenges addressing – too many L2 addresses for typical switches must balance load across many paths Ethernet routing too restrictive (even with advanced routing features) basic options: per packet load-balancing, flow-based load balancing requires new class of data center switches Some analysis of Amazon’s AWS scale: http://www.enterprisetech.com/2014/11/14/rare-peek-massive-scale-aws/

Blurring the L2/L3 Boundary Market forces are pushing Ethernet beyond the LAN traditionally, large volume of switch market has kept prices low smaller sales volume for routers kept prices high Technology improvements support greater capability early switches were simple and cheap (no VLANs, a few thousand routing table entries) modern switches can have >100K routing table entries and support thousands of VLANs, extensive IP features, ... market expectations have kept prices moderate, even as feature sets have ballooned Not clear how successful some advanced features will be big attraction of Ethernet is simple operation, but advanced features compromise simplicity challenge for new switches to interoperate with “legacy” switches

Putting It Together – An End-to-End Scenario browser DNS server Comcast network 68.80.0.0/13 school network 68.80.2.0/24 web page web server Google’s network 64.233.160.0/19 64.233.169.105

A day in the life… connecting to the Internet connecting laptop needs to get its own IP address, addr of first-hop router, addr of DNS server: use DHCP DHCP UDP IP Eth Phy DHCP DHCP router (runs DHCP) DHCP request encapsulated in UDP, encapsulated in IP, encapsulated in 802.3 Ethernet DHCP DHCP DHCP UDP IP Eth Phy DHCP Ethernet frame broadcast (dest: FFFFFFFFFFFF) on LAN, received at router running DHCP server Ethernet demuxed to IP demuxed, UDP demuxed to DHCP

A day in the life… connecting to the Internet DHCP server formulates DHCP ACK containing client’s IP address, IP address of first-hop router for client, name & IP address of DNS server DHCP DHCP UDP IP Eth Phy router (runs DHCP) encapsulation at DHCP server, frame forwarded (switch learning) through LAN, demultiplexing at client DHCP UDP IP Eth Phy DHCP DHCP DHCP client receives DHCP ACK reply DHCP Client now has IP address, knows name & addr of DNS server, IP address of its first-hop router

A day in the life… ARP (before DNS, before HTTP) before sending HTTP request, need IP address of www.google.com: DNS DNS UDP IP Eth Phy DNS router (runs DHCP) DNS query created, encapsulated in UDP, encapsulated in IP, encapsulated in Eth. To send frame to router, need MAC address of router interface: ARP ARP ARP query Eth Phy ARP ARP query broadcast, received by router, which replies with ARP reply giving MAC address of router interface ARP reply client now knows MAC address of first hop router, so can now send frame containing DNS query

A day in the life… using DNS UDP IP Eth Phy DNS DNS server DNS UDP IP Eth Phy DNS router (runs DHCP) DNS DNS DNS DNS Comcast network 68.80.0.0/13 IP datagram forwarded from campus network into comcast network, routed (tables created by OSPF, IS-IS, EIGRP and/or BGP routing protocols) to DNS server IP datagram containing DNS query forwarded via LAN switch from client to 1st hop router demux’ed to DNS server DNS server replies to client with IP address of www.google.com

A day in the life…TCP connection carrying HTTP IP Eth Phy router (runs DHCP) SYN SYNACK SYN to send HTTP request, client first opens TCP socket to web server TCP SYN segment (step 1 in 3-way handshake) inter-domain routed to web server TCP IP Eth Phy SYNACK SYN SYNACK web server responds with TCP SYNACK (step 2 in 3-way handshake) web server 64.233.169.105 TCP connection established!

A day in the life… HTTP request/reply web page finally (!!!) displayed HTTP TCP IP Eth Phy router (runs DHCP) HTTP HTTP HTTP HTTP request sent into TCP socket IP datagram containing HTTP request routed to www.google.com HTTP TCP IP Eth Phy HTTP web server responds with HTTP reply (containing web page) HTTP web server IP datagram containing HTTP reply routed back to client 64.233.169.105

Exercise C D E A F B id=3 id=7 f c d In the diagram at right, suppose that host d is on vlan 7 at switch D, host f is on vlan 3 at switch F and router c is on switch C and has connections to both VLANs. What sequence of links is used by a packet going from d to f assuming no other routers?

Exercise C D E A F B id=3 id=7 f c d In the diagram at right, suppose that host d is on vlan 7 at switch D, host f is on vlan 3 at switch F and router c is on switch C and has connections to both VLANs. What sequence of links is used by a packet going from d to f assuming no other routers? The packet would need to be delivered to router c so that it can be forwarded from vlan 7 to vlan 3. Assuming that host d knows the MAC address of router c and that entries are present in the switch forwarding tables of vlan 7 for that MAC address, the packet from host d is forwarded on links D-F, F-E, E-B, and B-C. Assuming that router c knows the MAC address of host f and that that entries are present in the switch forwarding tables of vlan 3 for that MAC address, the packet from host d is forwarded on links C-A, A-E, and E-F.

Exercise C D A E F B The diagram at right represents a core network for some ISP. Assume all the nodes are MPLS switches and that each connects to one or more edge routers. Describe how MPLS can be used to distribute traffic between switches C and F to use two different paths. Show MPLS routing table entries for all the switches along these paths, using different labels on each hop. Can you spread the load like this if the nodes were all conventional routers, using OSPF-routing?

Exercise C D A E F B The diagram at right represents a core network for some ISP. Assume all the nodes are MPLS switches and that each connects to one or more edge routers. Describe how MPLS can be used to distribute traffic between switches C and F to use two different paths. Show MPLS routing table entries for all the switches along these paths, using different labels on each hop. Can you spread the load like this if the nodes were all conventional routers, using OSPF-routing? Two link disjoint paths between C and F are C-E-D-F and C-B-A-F. Two realize those paths, we need two distinct labels (or sets of labels). C would have two labels, say L1 and L2, associated with subnets connected to F. Each label would point to a different next hop, e.g., L1 points to E and L2 to B. Next would need associated label mappings at the intermediate MPLS switches on each path. Specifically, B would have an entry mapping incoming label L2 to next hop A with an outgoing label of L2A (which could be equal to L2), similarly, A would have an entry mapping incoming label L2A to next hop F and outgoing label L2F. A similar set of mappings would be present on the path C-E-D-F for label L1. In this case, a similar outcome could be realized with OSPF, if both paths were equal cost shortest paths. In this case, traffic would be load-balanced across both paths.