Nick Gordon | f3a9ecb | 2017-01-24 13:55:14 -0600 | [diff] [blame] | 1 | \section{Sync Logic Handler} |
| 2 | \label{sec:sync-logic} |
| 3 | |
| 4 | The Sync Logic Handler acts as the interface between the synchronization protocol and the NLSR application. |
Nick Gordon | 221531c | 2017-06-08 11:44:45 -0500 | [diff] [blame^] | 5 | The Sync Logic Handler receives notifications from the synchronization protocol when another router updates an LSA, where an update can be modification of the contents of the LSA, or just incrementing the sequence number to refresh it. The Sync Logic Handler then determines if the updated LSA should be retrieved. The Sync Logic Handler is also how NLSR notifies the sync protocol when its own LSAs are updated. |
Nick Gordon | f3a9ecb | 2017-01-24 13:55:14 -0600 | [diff] [blame] | 6 | |
| 7 | \subsection{On Sync Update} |
Nick Gordon | 221531c | 2017-06-08 11:44:45 -0500 | [diff] [blame^] | 8 | When the sync protocol receives an update, the procedure roughly is this: |
| 9 | \begin{itemize} |
| 10 | \item For each name in the update: |
| 11 | \item Check that the sequence number in the LSA is newer than the one stored in the LSDB. |
| 12 | \item If so, tell the LSDB to fetch this new LSA. The LSDB will finish processing. |
| 13 | \end{itemize} |
| 14 | |
| 15 | When the synchronization protocol receives a sync update, which may contain multiple distinct items, the names and sequence numbers of each item will be passed to \texttt{SyncLogicHandler::onNsyncUpdate()}. |
| 16 | %% This may not be necessary. It is currently true, though. |
| 17 | % The Sync Logic Handler will process each updated name individually first by verifying that the update is not for one of the router's own LSAs. |
| 18 | Since other syncs in the network blindly transmit what they think is new, we need to check that it's new \emph{to us}, and we use the LSA sequence number to do that. The higher sequence number of the locally-stored LSA with the same name as in the update and the sequence number in the update is taken to be the newer one, noting that an absent LSA has a sequence number of 0. |
| 19 | If the update is found to be newer, the Sync Logic Handler will call \texttt{Lsdb::expressInterest()}, which attempts to fetch the LSA represented by the update. Other LSDB methods will finish processing and installing the new LSA. (Section~\ref{sec:lsdb}) |
Nick Gordon | f3a9ecb | 2017-01-24 13:55:14 -0600 | [diff] [blame] | 20 | |
| 21 | \subsection{Publish Routing Update} |
| 22 | \label{sssec:routing-update} |
Nick Gordon | 221531c | 2017-06-08 11:44:45 -0500 | [diff] [blame^] | 23 | When any of a router's LSAs are updated or refreshed by the LSDB, the LSDB will use the \\ \texttt{SyncLogicHandler::publishRoutingUpdate()} method to notify the sync protocol that the sequence number for that LSA has changed. |
| 24 | The Sync Logic Handler will also write the updated sequence number to file, so that a restarting router can continue publishing routing updates with sequence numbers larger than the sequence numbers it had published before. This is only an optimization. If a router were to reset its sequence number to 1, other routers would initially reject these LSAs as not being new. However, the LSAs in their LSDBs would eventually expire, since they are not being refreshed anymore. Once those LSAs expire, the LSAs that the restarted router is publishing would then be considered new. However, this process could take quite a while, so we optimize by resuming numbering where we left off. |