NFD forwarding pipelines Junxiao Shi,

Slides:



Advertisements
Similar presentations
Internetworking II: MPLS, Security, and Traffic Engineering
Advertisements

Delivery and Forwarding of
Interest NACK Junxiao Shi, Introduction Interest NACK, aka "negative acknowledgement", is sent from upstream to downstream to inform that.
CPIT 102 CPIT 102 CHAPTER 1 COLLABORATING on DOCUMENTS.
© 2006 Cisco Systems, Inc. All rights reserved. MPLS v2.2—2-1 Label Assignment and Distribution Introducing Typical Label Distribution in Frame-Mode MPLS.
What's inside a router? We have yet to consider the switching function of a router - the actual transfer of datagrams from a router's incoming links to.
1 Spring Semester 2007, Dept. of Computer Science, Technion Internet Networking recitation #4 Mobile Ad-Hoc Networks AODV Routing.
Routing and Routing Protocols Introduction to Static Routing.
Delivery, Forwarding, and Routing
TCP/IP Protocol Suite 1 Chapter 6 Upon completion you will be able to: Delivery, Forwarding, and Routing of IP Packets Understand the different types of.
NFD forwarding pipelines Junxiao Shi,
NFD forwarding pipelines Junxiao Shi,
Hash, Don’t Cache: Fast Packet Forwarding for Enterprise Edge Routers Minlan Yu Princeton University Joint work with Jennifer.
Computer Networks Layering and Routing Dina Katabi
Forwarding Hint in NFD Junxiao Shi,
1 Internet Protocol: Forwarding IP Datagrams Chapter 7.
SNAMP: Secure Namespace Mapping to Scale NDN Forwarding Alex Afanasyev (University of California, Los Angeles) Cheng Yi (Google) Lan Wang (University of.
M. Menelaou CCNA2 DYNAMIC ROUTING. M. Menelaou DYNAMIC ROUTING Dynamic routing protocols can help simplify the life of a network administrator Routing.
© Janice Regan, CMPT 128, CMPT 371 Data Communications and Networking BGP, Flooding, Multicast routing.
Dead Nonce List Junxiao Shi Bug 1953: persistent loop with short InterestLifetime A B C Interest Nonce=204 lifetime=150 delay=100 delay=20.
CSC 336 Data Communications and Networking Lecture 7d: Interconnecting LAN Dr. Cheer-Sun Yang Spring 2001.
Access Strategy Junxiao Shi, Problem 2.
NFD forwarding pipelines Junxiao Shi,
Interest NACK Junxiao Shi, Introduction Interest NACK, aka "negative acknowledgement", is sent from upstream to downstream to inform that.
The Routing Table: A Closer Look
1 Network Layer Lecture 13 Imran Ahmed University of Management & Technology.
Chapter 6 Delivery and Forwarding of IP Packets
NFD forwarding pipelines Junxiao Shi,
Authors: Haowei Yuan, Tian Song, and Patrick Crowley Publisher: ICCCN 2012 Presenter: Chai-Yi Chu Date: 2013/05/22 1.
Delivery, Forwarding, and Routing of IP Packets
The Routing Table Last Update Copyright Kenneth M. Chipps Ph.D.
Border Gateway Protocol (BGP) W.lilakiatsakun. BGP Basics (1) BGP is the protocol which is used to make core routing decisions on the Internet It involves.
Interest NACK Junxiao Shi, Introduction Interest NACK, aka "negative acknowledgement", is sent from upstream to downstream to inform that.
Multiplexing FDM & TDM. Multiplexing When two communicating nodes are connected through a media, it generally happens that bandwidth of media is several.
NFD Permanent Face Junxiao Shi, Outline what is a permanent face necessity and benefit of having permanent faces guarantees provided by.
NFD tables conceptual structure and algorithms Junxiao Shi,
Authors: Matteo Varvello, Diego Perino, and Leonardo Linguaglossa Publisher: NOMEN 2013 (The 2nd IEEE International Workshop on Emerging Design Choices.
NFD Tunnel Authentication Junxiao Shi,
Duplicate Suppression on Multicast Face Junxiao Shi
1 Data Link Layer Lecture 23 Imran Ahmed University of Management & Technology.
1 Version 3.1 Module 6 Routed & Routing Protocols.
Describe basic routing concepts. Routers Interconnect Networks Router is responsible for forwarding packets from network to network, from the original.
RIP Routing Protocol. 2 Routing Recall: There are two parts to routing IP packets: 1. How to pass a packet from an input interface to the output interface.
NFD forwarding pipelines Junxiao Shi,
NFD forwarding pipelines Junxiao Shi,
1 An SDL Tutorial Two primary elements: –Structure –Identifies the various components of the system, and the communication paths among them. –Components:
Fast Forwarding for NDN Won So Ashok Narayanan Mark Stapp Cisco Systems IETF ICNRG, 31/7/2013, Berlin.
Cliquez pour modifier le style du titre Cliquez pour modifier les styles du texte du masque Deuxième niveau Troisième niveau Quatrième niveau Cinquième.
ROUTING.
NFD Tunnel Authentication
Access Strategy Junxiao Shi,
NFD forwarding pipelines
Forwarding and Routing IP Packets
Chapter 6 Delivery & Forwarding of IP Packets
CS4470 Computer Networking Protocols
Internet Networking recitation #4
Chapter 4: Access Control Lists (ACLs)
Improving the Freshness of NDN Forwarding States
Dr. John P. Abraham Professor UTPA
Delivery and Routing of IP Packets
Chapter 2: Static Routing
Dr. John P. Abraham Professor UTRGV, EDINBURG, TX
Closure Representations in Higher-Order Programming Languages
Chapter 10 IGMP Prof. Choong Seon HONG.
Dr. John P. Abraham Professor UTPA
Chapter 3 Part 3 Switching and Bridging
Delivery, Forwarding, and Routing of IP Packets
10/18: Lecture Topics Using spatial locality
Assertions and Triggers
NFD Tunnel Authentication
Presentation transcript:

NFD forwarding pipelines Junxiao Shi,

Overview Forwarding consists of pipelines and strategies Pipeline: a series of steps that operate on a packet or a PIT entry Strategy: a decision maker on whether, when, and where to forward an Interest 2

Pipelines incoming Interest Interest loop ContentStore miss ContentStore hit outgoing Interest Interest reject Interest unsatisfied Interest finalize incoming Data Data unsolicited outgoing Data incoming Nack outgoing Nack 3

Legend in diagrams 4 building block pipeline tables feature strategy face feature

Pipelines Overall Workflow 5 incoming Interest incoming Data outgoing Interest outgoing Data after receive Interest Interest reject Interest unsatisfied Interest loop Data unsolicited before satisfy Interest before expire Interest unsatisfy timer straggler timer Interest finalize ContentStore miss ContentStore hit incoming Nack after receive Nack outgoing Nack

incoming Interest pipeline 6 CS lookup PIT insert cancel unsatisfy & straggler timer Y receive Interest detect duplicate Nonce in PIT entry Interest loop Y is pending? Y violates /localhost? N (drop) ContentStore miss ContentStore hit Y N N N detect duplicate Nonce with Dead Nonce List N Y

detect duplicate Nonce If the Name+Nonce of the incoming Interest appear in Dead Nonce List, or any InRecord or OutRecord in PIT entry contains the same Nonce as the incoming Interest, a duplicate Nonce is detected. If the duplicate Nonce is found in InRecord only, this is a multi-path arrival, and not a loop. If the duplicate Nonce is found in OutRecord or Dead Nonce Table, this is either a multi-path arrival or a loop, and these two reasons are indistinguishable. Nonce is later recorded on an InRecord. 7

Interest loop pipeline Process an Interest that has been considered looped. Keep this simple for now: unconditionally send Nack- Duplicate when duplicate Nonce is detected. Don't enter outgoing Nack pipeline: in-record isn't inserted yet. In the future, strategy could be invoked, because duplicate Nonce may be multi-path arrival instead of loop. 8 reason=Duplicate send Nack is multi-access face? (drop) N Y

ContentStore miss pipeline This pipeline is entered when an incoming Interest is pending (so ContentStore lookup is unnecessary), or is miss from ContentStore This pipeline will start forwarding the Interest 9

ContentStore miss pipeline 10 FIB lookup with Interest Name dispatch to strategy insert InRecord set PIT unsatisfy timer Interest unsatisfied timer event in producer region? has Selected Delegation ? FIB lookup with SelectedDelegation choose and set SelectedDelegation Y N N Y FIB lookup with first Delegation Name in default- free zone? Y N has Link object? N Y

set PIT unsatisfy timer Given PIT entry, set an unsatisfy timer which fires when InterestLifetime expires for all unexpired InRecords When the unsatisfy timer fires, Interest unsatisfied pipeline is entered 11

determine whether in producer region Input: regionNames: the router's region names, from configuration interest Algorithm: 1.foreach delegation in Link: 1.foreach regionName in regionNames: 1.if delegation Name is a prefix of regionName, return true and abort these steps 2.return false Note: We consider all delegations, not just SelectedDelegation, to maximize flexibility. This is cheap because there's no table lookup. 12

determine whether in default- free zone Input: interest, with Link but without SelectedDelegation FIB lookup result for the first delegation Algorithm: 1.if FIB lookup result is the root entry (ndn:/), and the entry has at least one nexthop record, return false 2.return true Note: FIB lookup will never return "no match", because the FIB always has a root entry, but this entry can have no nexthop record. We consider only the first delegation, to minimize table lookup cost. Checking all delegations probably gives better results, but it requires too many lookups. 13

choose and set SelectedDelegation Input: interest, with Link but without SelectedDelegation FIB Algorithm: 1.foreach delegation in Link, sorted by increasing Preference 1.lookup FIB with delegation Name 2.if a match (with non-zero nexthop records) is found, insert SelectedDelegation field with the index of this delegation, return the match, and abort these steps 2.lookup FIB with Interest Name Note: This is the only operation that requires multiple table lookups, but it happens only once on an Interest's path at the first default-free router. 14

15 outgoing Data set PIT straggler timer timer event Interest finalize ContentStore hit pipeline

dispatch incoming Interest to strategy Given FIB entry and incoming Interest, determine which strategy should process this Interest, and trigger that strategy 16

outgoing Interest pipeline 17 insert OutRecord pick Interest send Interest violates /localhost? Y (drop) violates /localhop? (drop) Y NN

pick outgoing Interest packet Given PIT entry and nexthop, decide the guiders on the outgoing Interest Nonce and InterestLifetime come from an InRecord with longest remaining lifetime, however InRecord with same Face as the nexthop cannot be used InterestLifetime is carried from the original packet without deducting the time elapsed Scope is the most relaxed among all unexpired InRecords The last incoming Interest is picked This is a simple choice until we understand the effect of guiders better 18

Interest reject pipeline Process an Interest that has been decided that it has nowhere to go 19 set PIT straggler timer timer event cancel unsatisfy & straggler timer Interest finalize

Interest unsatisfied pipeline 20 invoke PIT unsatisfied callback Interest finalize

Interest finalize pipeline 21 PIT delete Dead Nonce List insert need Dead Nonce List insert? Y N

Dead Nonce List insert Dead Nonce List insertion is needed if: Interest is unsatisified, OR Interest has MustBeFresh=yes and Data FreshnessPeriod is shorter than 6 seconds Nonces in OutRecords are inserted to Dead Nonce List. 22

incoming Data pipeline 23 PIT match receive Data Y CS insert outgoing Data cancel unsatisfy & straggler timer mark PIT satisfied set PIT straggler timer foreach PIT entry foreach pending downstream Data unsolicited timer event violates /localhost? Y (drop) invoke PIT satisfy callback Interest finalize Dead Nonce List insert need Dead Nonce List insert? Y N N N

set PIT straggler timer Given PIT entry, set a straggler timer which fires after a short time T straggler = 100ms When the straggler timer fires, PIT entry is deleted The purpose of retaining PIT entry for a short time is to facilitate loop detection and to collect measurement for non-fastest upstreams 24

Data unsolicited pipeline 25 accept to cache? Y CS insert N

outgoing Data pipeline 26 traffic managersend Data violates /localhost? Y (drop) N

Pass-through traffic manager Provide a traffic manager that does nothing and merely passes Data packet to the next step 27

Incoming Nack pipeline PIT match receive Nack trigger strategy: after receive Nack (drop) mark out-record as Nacked N has out-record with correct Nonce? Y (drop) N Y 28 is multi-access face? N Y (drop)

Outgoing Nack pipeline send Nack strategy action: send Nack erase in-record has in- record? (drop) N Y 29 is multi-access face? N Y (drop)