Nick Gordon | f3a9ecb | 2017-01-24 13:55:14 -0600 | [diff] [blame] | 1 | \section{Introduction} |
| 2 | \label{sec:intro} |
| 3 | |
| 4 | The Named-data Link State Routing protocol (NLSR) is an intra-domain routing protocol for Named Data Networking (NDN). |
| 5 | It is an application level protocol similar to many IP routing protocols, but NLSR uses NDN's Interest/Data packets to disseminate routing updates. |
| 6 | Although NLSR is designed in the context of a single domain, its design patterns may offer a useful reference for future development of inter-domain routing protocols. |
| 7 | |
| 8 | NLSR supports name-based routing in NDN, computes routing ranks for all policy-compliant next-hops which provides a name-based multi-path routing table for NDN's forwarding strategy, |
| 9 | and ensures that routers can originate only their own routing updates using a hierarchical trust model. |
| 10 | |
| 11 | \subsection{NLSR Modules and Data Structures} |
| 12 | \label{sec:modules} |
| 13 | NLSR contains multiple modules that each contribute to the total realization of the protocol. |
| 14 | Many of the modules interact with one another to trigger some behavior or to modify information in data structures. |
| 15 | NLSR uses the following modules: |
| 16 | \begin{itemize} |
| 17 | \item \textbf{Hello Protocol} (Section~\ref{sec:hello-protocol}) - determines the status of neighboring routers using periodic Hello Interests and notifies other modules when neighbors' statuses change. |
| 18 | \item \textbf{NSync} - provides LSDB synchronization by extending the ChronoSync protocol~\cite{chronosync}. |
| 19 | \item \textbf{Sync Logic Handler} (Section~\ref{sec:sync-logic}) - handles sync update notifications from NSync by retrieving updated LSAs. |
| 20 | \item \textbf{LSAs} (Section~\ref{sec:lsas}) - represent routing information published by the router. |
| 21 | \item \textbf{LSDB} (Section~\ref{sec:lsdb}) - stores the LSA information distributed by other routers in the network. |
| 22 | \item \textbf{Routing Table} (Section~\ref{sec:routing-table}) - calculates and maintains a list of next hops for each router in the network. |
| 23 | \item \textbf{Name Prefix Table} (Section~\ref{sec:npt}) - stores all advertised name prefixes and their next hops. |
| 24 | \item \textbf{FIB} (Section~\ref{sec:fib}) - maintains a shadow FIB which represents the intended state of NFD's FIB~\cite{NFD}. |
| 25 | \item \textbf{Prefix Update Processor} - listens for dynamic prefix announcements to advertise or withdraw name prefixes. |
| 26 | \end{itemize} |
| 27 | |
| 28 | \subsection{Protocol Overview} |
| 29 | \label{sec:protocol-overview} |
| 30 | |
| 31 | NLSR is designed to accomplish three main tasks: (1) discover adjacent neighbors; (2) disseminate and synchronize topology, name prefix, and hyperbolic routing information; and (3) calculate a consistent routing table and populate NFD's FIB. |
| 32 | The entire protocol is described in detail in the NLSR paper~\cite{NlsrTr}. |
| 33 | |
| 34 | \subsubsection{Discovering Neighbors} |
| 35 | |
| 36 | NLSR determines the adjacency status of neighboring routers using the Hello Protocol module (Section~\ref{sec:hello-protocol}). |
| 37 | When the Hello Protocol detects a status change for a neighbor, it will ask the LSDB module (Section~\ref{sec:lsdb}) to update the router's advertised adjacency information. |
| 38 | |
| 39 | \subsubsection{Disseminating Routing Information} |
| 40 | |
| 41 | When one of a router's LSAs (Section~\ref{sec:lsas}) changes, the information of this change should be distributed to every other router in the network. |
| 42 | The Sync Logic Handler module (Section~\ref{sec:sync-logic}) is used to notify the synchronization protocol of changes to the router's own LSAs as well as to learn of LSA changes from other routers in the network; |
| 43 | the Sync Logic Handler module interfaces with NSync to perform the two tasks. |
| 44 | |
| 45 | When the Sync Logic Handler module learns of a new LSA, it will inform the LSDB module. |
| 46 | The LSDB module will attempt to fetch the new LSA and will store it in the LSDB module's database if it can be retrieved. |
| 47 | If the newly fetched LSA informs the router of previously unknown routing information, the LSDB module will inform other modules depending on the type of routing information: |
| 48 | \begin{itemize} |
| 49 | \item \textbf{Change in network topology} - the LSDB module will inform the Routing Table module (Section~\ref{sec:routing-table}), so the Routing Table module can calculate an up-to-date routing table. |
| 50 | \item \textbf{Change in name prefix advertisement} - the LSDB module will inform the Name Prefix Table module (Section~\ref{sec:npt}), which will in turn notify the FIB module (Section~\ref{sec:fib}) in order to add or remove the changed name prefixes. |
| 51 | \item \textbf{Change in hyperbolic coordinates} - the LSDB module will inform the Routing Table module (Section~\ref{sec:routing-table}), so the Routing Table module can calculate an up-to-date routing table. |
| 52 | \end{itemize} |
| 53 | |
| 54 | \subsubsection{Calculating the Routing Table and Populating NFD's FIB} |
| 55 | |
| 56 | When the routing table is calculated by the Routing Table module, the computed next hops are passed to the Name Prefix Table module. |
| 57 | The Name Prefix Table module will then further pass the next hops to the FIB module to update NLSR's expected state of NFD's FIB. |
| 58 | The FIB module will then perform the registrations or unregistrations with NFD's FIB.\\ |
| 59 | |
| 60 | A simplified diagram of NLSR's actions when receiving new routing information is shown in Figure~\ref{fig:system-interaction}. |
| 61 | The remainder of this documentation will describe the purpose of and interaction between each module in more detail. |
| 62 | |
| 63 | \begin{figure} |
| 64 | \center |
Nick Gordon | eafb2a2 | 2017-01-24 14:55:56 -0600 | [diff] [blame] | 65 | \includegraphics[width=\linewidth]{figures/system-interaction.pdf} |
Nick Gordon | f3a9ecb | 2017-01-24 13:55:14 -0600 | [diff] [blame] | 66 | \caption{Simplified Diagram of the Actions of NLSR's Modules} |
| 67 | \label{fig:system-interaction} |
| 68 | \end{figure} |
| 69 | |
Nick Gordon | f750ef5 | 2017-02-13 13:28:09 -0600 | [diff] [blame^] | 70 | \subsection{Dispatcher} |
| 71 | \label{sec:dispatcher} |
| 72 | |
| 73 | NLSR takes advantage of a variety of ndn-cxx convenience |
| 74 | mechanisms. Among these is the dispatcher. The dispatcher provides |
| 75 | facilities for receiving and decoding ControlCommands, which |
| 76 | simplifies the processing workflow. The dispatcher itself is |
| 77 | \href{http://named-data.net/doc/ndn-cxx/current/doxygen/de/d34/classndn_1_1mgmt_1_1Dispatcher.html}{well-documented}, |
| 78 | so we will only give a brief overview here. |
| 79 | |
| 80 | \begin{itemize} |
| 81 | \item Any prefixes that are registered, such as ``prefix/register'', |
| 82 | \emph{must} be registered before top-level prefixes. All prefix |
| 83 | registrations should go in \texttt{Nlsr::registerLocalhostPrefix}. |
| 84 | \item The dispatcher can be used to accept incoming ControlCommands |
| 85 | and respond to requests for datasets. Currently NLSR uses the |
| 86 | dispatcher only for accepting incoming ControlCommands. |
| 87 | \item Top-level prefixes cannot overlap. For example, you cannot |
| 88 | register ``/localhost/nlsr'' and then ``/localhost/nlsr/fib''. The |
| 89 | second registration must be done as a sub-prefix of the first, |
| 90 | i.e. the first prefix, and then ``fib''. |
| 91 | \end{itemize} |