StatusDataset » History » Revision 7
« Previous |
Revision 7/8
(diff)
| Next »
Davide Pesavento, 10/30/2021 08:10 PM
Status Dataset¶
Status Dataset is a mechanism of NFD Management protocol.
This document defines how status information about a collection of entities is encoded, segmented, and published as Data packets.
Status Dataset is used by:
- FaceManager: to publish the description of all active faces and their counters
- FibManager: to publish all FIB entries and nexthop records
- StrategyChoiceManager: to publish strategy choices for namespaces
- RibManager: to publish all RIB entries and routes
Specification¶
Encoding
Status information of each entity is represented by a TLV block.
Those TLV blocks are concatenated into a BLOB.
Segmentation
The BLOB is segmented into one or more Data packets, such that each Data packet does not exceed the size limit.
Segmentation does not consider the boundary between TLV blocks.
Data Naming
A status dataset is publish under a certain Name prefix.
Every Data packet has Name /<prefix>/<version>/<segment>
.
The version component is a NameComponentWithMarkerAndNumber
, as in NDN Naming Conventions (rev 1).
This component starts with a 0xFD
marker, followed by a NonNegativeInteger
.
The version number is monotonic increasing during the lifetime of the producer;
it could be but is not necessarily a timestamp.
The segment component is a NameComponentWithMarkerAndNumber
, as in NDN Naming Conventions (rev 1).
This component starts with a 0x00
marker, followed by a NonNegativeInteger
.
The first segment has segment number zero.
An example Name is: /example/dataset/%FD%00%00%01G%BB%82%CB%A8/%00%01
.
This represents the second segment (segment number 1) in version 1407600217000 of a dataset at /example/dataset
.
FinalBlockId field contains the segment component of the last segment.
This field MUST appear in the last segment, and MAY appear in other segments.
Operations¶
To request a status dataset, the consumer should:
- send an Interest
/example/dataset
, CanBePrefix=yes, MustBeFresh=yes - wait for Data; if no Data arrives, fail
- take note of version in the arriving Data Name
- send Interest(s)
/example/dataset/<version>/<segment>
to retrieve other segments - repeat step 4 until all segments are retrieved
- sort segments in order, concatenate the Content of all segments to obtain the BLOB
- parse the BLOB into a series of TLV blocks each represents the status information of an entity
To publish a status dataset, the producer should:
- listen on prefix
/example/dataset
- upon receiving an Interest, if the Interest Name is longer than
/example/dataset
(it contains version and/or segment), don't respond and abort these steps- these Interests should be satisfied by the ContentStore
- generate a new version number
- collect status TLV blocks, concatenate into the BLOB, and segment it into Data packets
- put all Data packets
- the first Data packet (preferably the first segment) satisfies the Interest
- other Data packets are admitted to the ContentStore as unsolicited Data
Updated by Davide Pesavento about 3 years ago · 8 revisions