blob: 4ee93c6973a75d4858f0d8fedfaffd66ef8a074d [file] [log] [blame]
Steve DiBenedetto62a93942014-08-24 17:13:52 -06001Getting Started with NFD
2========================
Alexander Afanasyev284257b2014-04-11 14:16:51 -07003
Davide Pesavento69857c32020-04-05 16:36:26 -04004Supported platforms
5-------------------
Steve DiBenedetto62a93942014-08-24 17:13:52 -06006
Davide Pesavento69857c32020-04-05 16:36:26 -04007NFD is built against a continuous integration system and has been tested on the
8following platforms:
9
10- Ubuntu 16.04 (amd64)
11- Ubuntu 18.04 (amd64, armhf, i386)
12- Ubuntu 19.10 (amd64)
13- macOS 10.13
14- macOS 10.14
15- macOS 10.15
16
17NFD is known to work on the following platforms, although they are not officially
18supported:
19
20- Debian >= 9
21- Gentoo Linux
22- Raspbian >= 2017-08-16
23
24.. _Install NFD on Ubuntu Linux using the NDN PPA repository:
25
26Install NFD on Ubuntu Linux using the NDN PPA repository
Steve DiBenedetto62a93942014-08-24 17:13:52 -060027--------------------------------------------------------
28
Davide Pesavento69857c32020-04-05 16:36:26 -040029NFD binaries and related tools for supported versions of Ubuntu can be installed using
30PPA packages from the **named-data** repository. First, you will need to add the
31``named-data/ppa`` repository to the binary package sources and update the list of
32available packages.
Steve DiBenedetto62a93942014-08-24 17:13:52 -060033
Alexander Afanasyev84dd4ca2017-10-15 14:56:08 -040034Preliminary steps if you have not used PPA packages before
35~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
Steve DiBenedetto62a93942014-08-24 17:13:52 -060036
Davide Pesavento69857c32020-04-05 16:36:26 -040037To simplify adding new PPA repositories, Ubuntu provides the ``add-apt-repository`` tool,
Davide Pesaventocc7bee72016-04-22 02:21:13 +020038which is not installed by default on some systems.
Steve DiBenedetto62a93942014-08-24 17:13:52 -060039
40::
41
Davide Pesavento69857c32020-04-05 16:36:26 -040042 sudo apt install software-properties-common
Steve DiBenedetto62a93942014-08-24 17:13:52 -060043
Davide Pesavento69857c32020-04-05 16:36:26 -040044Adding the NDN PPA
45~~~~~~~~~~~~~~~~~~
Steve DiBenedetto62a93942014-08-24 17:13:52 -060046
Davide Pesavento69857c32020-04-05 16:36:26 -040047After installing ``add-apt-repository``, run the following commands to add the `NDN PPA
48repository`_::
Steve DiBenedetto62a93942014-08-24 17:13:52 -060049
50 sudo add-apt-repository ppa:named-data/ppa
Davide Pesavento69857c32020-04-05 16:36:26 -040051 sudo apt update
Steve DiBenedetto62a93942014-08-24 17:13:52 -060052
53Installing NFD and other NDN packages
54~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
55
Davide Pesavento69857c32020-04-05 16:36:26 -040056After you have added the `NDN PPA repository`_, NFD and other NDN packages can be easily
57installed either using ``apt``, as shown below, or any other compatible package manager.
Steve DiBenedetto62a93942014-08-24 17:13:52 -060058
59::
60
Davide Pesavento69857c32020-04-05 16:36:26 -040061 sudo apt install nfd
Steve DiBenedetto62a93942014-08-24 17:13:52 -060062
Davide Pesavento69857c32020-04-05 16:36:26 -040063For the list of available packages, refer to the `NDN PPA repository`_ page.
Steve DiBenedetto62a93942014-08-24 17:13:52 -060064
65.. _NDN PPA repository: https://launchpad.net/~named-data/+archive/ppa
66
Davide Pesavento69857c32020-04-05 16:36:26 -040067Building from source
Steve DiBenedetto62a93942014-08-24 17:13:52 -060068--------------------
69
Davide Pesavento69857c32020-04-05 16:36:26 -040070Downloading from git
Steve DiBenedetto62a93942014-08-24 17:13:52 -060071~~~~~~~~~~~~~~~~~~~~
72
Davide Pesavento69857c32020-04-05 16:36:26 -040073The first step is to obtain the source code for NFD and its main dependency, the
74*ndn-cxx* library. If you do not want a development version of NFD, make sure you
75checkout the correct release tag (e.g., ``*-0.7.0``) from both repositories.
Steve DiBenedetto62a93942014-08-24 17:13:52 -060076
77::
78
79 # Download ndn-cxx
Davide Pesavento69857c32020-04-05 16:36:26 -040080 git clone https://github.com/named-data/ndn-cxx.git
Steve DiBenedetto62a93942014-08-24 17:13:52 -060081
82 # Download NFD
Davide Pesavento69857c32020-04-05 16:36:26 -040083 git clone --recursive https://github.com/named-data/NFD.git
Alexander Afanasyev284257b2014-04-11 14:16:51 -070084
Alexander Afanasyev84dd4ca2017-10-15 14:56:08 -040085.. note::
Davide Pesavento69857c32020-04-05 16:36:26 -040086 While we strive to ensure that the latest version (git master branch) of NFD and ndn-cxx
87 always compiles and works properly, we cannot guarantee that there will be no issues.
88 If this is discovered to be the case, please use matching released versions (git tag or
89 tarball) of NFD and ndn-cxx instead.
Alexander Afanasyev84dd4ca2017-10-15 14:56:08 -040090
Alexander Afanasyev284257b2014-04-11 14:16:51 -070091Prerequisites
Steve DiBenedetto62a93942014-08-24 17:13:52 -060092~~~~~~~~~~~~~
Alexander Afanasyev284257b2014-04-11 14:16:51 -070093
Davide Pesavento69857c32020-04-05 16:36:26 -040094Install the `ndn-cxx library <https://named-data.net/doc/ndn-cxx/current/INSTALL.html>`__
95and its prerequisites.
Alexander Afanasyev284257b2014-04-11 14:16:51 -070096
Davide Pesavento69857c32020-04-05 16:36:26 -040097On Linux, NFD needs the following dependencies to enable optional features:
Junxiao Shie5e1e252014-12-13 22:07:35 -070098
Davide Pesavento69857c32020-04-05 16:36:26 -040099- On Ubuntu::
Junxiao Shie5e1e252014-12-13 22:07:35 -0700100
Davide Pesavento69857c32020-04-05 16:36:26 -0400101 sudo apt install libpcap-dev libsystemd-dev
Alexander Afanasyev284257b2014-04-11 14:16:51 -0700102
Steve DiBenedetto62a93942014-08-24 17:13:52 -0600103Build
104~~~~~
105
Davide Pesavento69857c32020-04-05 16:36:26 -0400106The following commands can be used to build and install NFD from source::
Alexander Afanasyev284257b2014-04-11 14:16:51 -0700107
108 ./waf configure
109 ./waf
110 sudo ./waf install
111
Davide Pesavento69857c32020-04-05 16:36:26 -0400112If you have installed ndn-cxx and/or any other dependencies into a non-standard path,
113you may need to modify the ``PKG_CONFIG_PATH`` environment variable before running
114``./waf configure``. For example::
Alexander Afanasyev284257b2014-04-11 14:16:51 -0700115
Davide Pesavento69857c32020-04-05 16:36:26 -0400116 export PKG_CONFIG_PATH="/custom/lib/pkgconfig:$PKG_CONFIG_PATH"
Alexander Afanasyev284257b2014-04-11 14:16:51 -0700117 ./waf configure
118 ./waf
119 sudo ./waf install
120
Davide Pesavento69857c32020-04-05 16:36:26 -0400121Refer to ``./waf --help`` for more options that can be used during the ``configure`` stage.
Steve DiBenedetto62a93942014-08-24 17:13:52 -0600122
Alexander Afanasyev508411e2014-12-16 13:27:59 -0800123.. note::
Davide Pesavento69857c32020-04-05 16:36:26 -0400124 If you are working on a source repository that has been compiled before, and you have
125 upgraded one of the dependencies, please execute ``./waf distclean`` to clear object files
126 and start over.
Alexander Afanasyev508411e2014-12-16 13:27:59 -0800127
Alexander Afanasyev26181532014-05-07 23:38:51 -0700128Debug symbols
Steve DiBenedetto62a93942014-08-24 17:13:52 -0600129~~~~~~~~~~~~~
Alexander Afanasyev26181532014-05-07 23:38:51 -0700130
Davide Pesavento69857c32020-04-05 16:36:26 -0400131The default compiler flags enable debug symbols to be included in binaries. This should
132provide more meaningful debugging information if NFD or other tools happen to crash.
Alexander Afanasyev26181532014-05-07 23:38:51 -0700133
Davide Pesavento69857c32020-04-05 16:36:26 -0400134If this is undesirable, the default flags can be overridden to disable debug symbols.
135The following example shows how to completely disable debug symbols and configure NFD
136to be installed into ``/usr`` with configuration in the ``/etc`` directory.
Alexander Afanasyev26181532014-05-07 23:38:51 -0700137
138::
139
140 CXXFLAGS="-O2" ./waf configure --prefix=/usr --sysconfdir=/etc
141 ./waf
142 sudo ./waf install
143
Davide Pesavento69857c32020-04-05 16:36:26 -0400144For Ubuntu PPA packages, debug symbols are available in ``*-dbg`` packages.
Alexander Afanasyev84dd4ca2017-10-15 14:56:08 -0400145
Davide Pesavento69857c32020-04-05 16:36:26 -0400146Customizing the compiler
147~~~~~~~~~~~~~~~~~~~~~~~~
Alexander Afanasyev7c10b3b2015-01-20 12:24:27 -0800148
Davide Pesavento69857c32020-04-05 16:36:26 -0400149To build NFD with a different compiler (rather than the platform default), set the
150``CXX`` environment variable to point to the compiler binary. For example, to build
151with clang on Linux, use the following::
Alexander Afanasyev7c10b3b2015-01-20 12:24:27 -0800152
Eric Newberry81a9a862016-12-27 22:59:27 -0700153 CXX=clang++ ./waf configure
Alexander Afanasyev7c10b3b2015-01-20 12:24:27 -0800154
Davide Pesavento69857c32020-04-05 16:36:26 -0400155Building the documentation
156~~~~~~~~~~~~~~~~~~~~~~~~~~
Alexander Afanasyev284257b2014-04-11 14:16:51 -0700157
Davide Pesavento69857c32020-04-05 16:36:26 -0400158NFD tutorials and API documentation can be built using the following commands::
Alexander Afanasyev284257b2014-04-11 14:16:51 -0700159
160 # Full set of documentation (tutorials + API) in build/docs
161 ./waf docs
162
Davide Pesavento69857c32020-04-05 16:36:26 -0400163 # Only tutorials in build/docs
Alexander Afanasyev284257b2014-04-11 14:16:51 -0700164 ./waf sphinx
165
Davide Pesavento69857c32020-04-05 16:36:26 -0400166 # Only API docs in build/docs/doxygen
167 ./waf doxygen
Alexander Afanasyev284257b2014-04-11 14:16:51 -0700168
Davide Pesavento69857c32020-04-05 16:36:26 -0400169If ``sphinx-build`` is detected during ``./waf configure``, manpages are automatically
170built and installed during the normal build process (i.e., during ``./waf`` and ``./waf
171install``). By default, manpages are installed into ``${PREFIX}/share/man`` (the default
172value for ``PREFIX`` is ``/usr/local``). This location can be changed during the ``./waf
173configure`` stage using the ``--prefix``, ``--datarootdir``, or ``--mandir`` options.
Alexander Afanasyev284257b2014-04-11 14:16:51 -0700174
Davide Pesavento69857c32020-04-05 16:36:26 -0400175For more details, please refer to ``./waf --help``.
Steve DiBenedetto62a93942014-08-24 17:13:52 -0600176
Steve DiBenedetto62a93942014-08-24 17:13:52 -0600177Initial configuration
178---------------------
179
180.. note::
181 If you have installed NFD from binary packages, the package manager has already
Davide Pesavento69857c32020-04-05 16:36:26 -0400182 installed a working configuration and you can safely skip this section.
Steve DiBenedetto62a93942014-08-24 17:13:52 -0600183
184General
185~~~~~~~
186
Davide Pesavento69857c32020-04-05 16:36:26 -0400187After installing NFD from source, you need to create a proper configuration file.
188If the default installation directories were used with ``./waf configure``, this
189can be accomplished by simply copying the sample configuration file as follows::
Steve DiBenedetto62a93942014-08-24 17:13:52 -0600190
191 sudo cp /usr/local/etc/ndn/nfd.conf.sample /usr/local/etc/ndn/nfd.conf
192
193NFD Security
194~~~~~~~~~~~~
195
196NFD provides mechanisms to enable strict authorization for all management commands. In
Davide Pesavento69857c32020-04-05 16:36:26 -0400197particular, one can authorize only specific public keys to create new faces or change the
Steve DiBenedetto62a93942014-08-24 17:13:52 -0600198forwarding strategy for specific namespaces. For more information about how to generate
Davide Pesavento69857c32020-04-05 16:36:26 -0400199public/private key pairs, generate self-signed certificates, and use them to authorize
200NFD management commands, refer to the :ref:`How do I configure NFD security` FAQ question.
Steve DiBenedetto62a93942014-08-24 17:13:52 -0600201
Davide Pesavento69857c32020-04-05 16:36:26 -0400202In the sample configuration file, all security mechanisms are disabled for local clients,
203effectively allowing anybody on the local machine to issue NFD management commands.
204
205.. note::
206 The sample configuration file is intended only for demo purposes and should NOT be
207 used in production environments.
Steve DiBenedetto62a93942014-08-24 17:13:52 -0600208
209Running
210-------
211
Steve DiBenedetto62a93942014-08-24 17:13:52 -0600212Starting
213~~~~~~~~
214
Davide Pesavento69857c32020-04-05 16:36:26 -0400215If you have installed NFD from source, it is recommended to start NFD with the
216``nfd-start`` script::
Steve DiBenedetto62a93942014-08-24 17:13:52 -0600217
218 nfd-start
219
Davide Pesavento69857c32020-04-05 16:36:26 -0400220On macOS, this command may ask for your keychain password or ask "nfd wants to sign using
221key [xyz] in your keychain". Enter your keychain password and click "Always Allow".
Steve DiBenedetto62a93942014-08-24 17:13:52 -0600222
223Later, you can stop NFD with ``nfd-stop`` or by simply killing the ``nfd`` process.
224
Davide Pesavento2849fd42019-01-03 18:30:05 -0500225If you have installed NFD using a package manager, you can start and stop NFD using the
Davide Pesavento69857c32020-04-05 16:36:26 -0400226operating system's service manager, such as ``systemctl`` or ``launchctl``.
Steve DiBenedetto62a93942014-08-24 17:13:52 -0600227
Davide Pesavento69857c32020-04-05 16:36:26 -0400228Connecting to remote forwarders
229~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
Steve DiBenedetto62a93942014-08-24 17:13:52 -0600230
Davide Pesavento69857c32020-04-05 16:36:26 -0400231To create a UDP tunnel to a remote instance of NFD, execute the following command
232in a terminal::
Steve DiBenedetto62a93942014-08-24 17:13:52 -0600233
Davide Pesavento69857c32020-04-05 16:36:26 -0400234 nfdc face create udp://<other-host>
Steve DiBenedetto62a93942014-08-24 17:13:52 -0600235
Davide Pesavento69857c32020-04-05 16:36:26 -0400236where ``<other-host>`` is the name or IP address of the other host (e.g.,
237``udp://ndn.example.net``). If successful, this will print something like::
Steve DiBenedetto62a93942014-08-24 17:13:52 -0600238
Junxiao Shi849e12a2017-08-02 00:14:57 +0000239 face-created id=308 local=udp4://10.0.2.15:6363 remote=udp4://131.179.196.46:6363 persistency=persistent
240
Davide Pesavento69857c32020-04-05 16:36:26 -0400241To add a route ``/ndn`` toward this remote forwarder, execute the following command
242in a terminal::
Junxiao Shi849e12a2017-08-02 00:14:57 +0000243
Davide Pesavento69857c32020-04-05 16:36:26 -0400244 nfdc route add /ndn udp://<other-host>
Junxiao Shi849e12a2017-08-02 00:14:57 +0000245
Davide Pesavento69857c32020-04-05 16:36:26 -0400246This will print::
Junxiao Shi849e12a2017-08-02 00:14:57 +0000247
248 route-add-accepted prefix=/ndn nexthop=308 origin=static cost=0 flags=child-inherit expires=never
Steve DiBenedetto62a93942014-08-24 17:13:52 -0600249
Davide Pesavento69857c32020-04-05 16:36:26 -0400250This indicates that NFD will forward all Interests that start with ``/ndn`` through the
251face to the other host. This forwards Interests to the other host, but does not provide
252a "back route" for the other host to forward Interests to you. For this, you can rely on
253the "automatic prefix propagation" feature of NFD or use the ``nfdc`` command on the other
254host to add the route.
Steve DiBenedetto62a93942014-08-24 17:13:52 -0600255
256Playing with NFD
257----------------
258
Davide Pesavento69857c32020-04-05 16:36:26 -0400259After you have installed, configured, and started NFD, you can demonstrate the features
260of NDN using the following applications and libraries.
Steve DiBenedetto62a93942014-08-24 17:13:52 -0600261
262Sample applications:
263
Davide Pesavento69857c32020-04-05 16:36:26 -0400264 + `Simple examples using the ndn-cxx library <https://named-data.net/doc/ndn-cxx/current/examples.html>`_
265 + `Introductory examples of NDN-CCL
266 <https://redmine.named-data.net/projects/application-development-documentation-guides/wiki/Step-By-Step_-_Common_Client_Libraries>`_
Steve DiBenedetto62a93942014-08-24 17:13:52 -0600267
268Real applications and libraries:
269
Davide Pesavento69857c32020-04-05 16:36:26 -0400270 + `ndn-tools - Essential NDN command-line tools <https://github.com/named-data/ndn-tools>`_
271 + `ndn-traffic-generator - Traffic generator for NDN <https://github.com/named-data/ndn-traffic-generator>`_
272 + `repo-ng - Next generation NDN repository <https://github.com/named-data/repo-ng>`_
273 + `ChronoSync - Sync library for multi-user real-time applications <https://github.com/named-data/ChronoSync>`_
274 + `PSync - Partial and full synchronization library <https://github.com/named-data/PSync>`_