Netatalk Installation Quick Start

This guide covers installing Netatalk from source on UNIX-like operating
systems.

Netatalk uses the Meson build system with Ninja as the backend.

Meson only supports out-of-tree builds, and must be passed a directory to put
built and generated sources into. We'll call that directory "build" here. It's
recommended to create a separate build directory for each configuration you
might want to use.

Get the source code

To build from a release tarball, download and unpack the tarball.

tar xjf netatalk-*.tar.xz                               # unpack the sources
cd netatalk-*                                           # change to the toplevel directory

To build from the Netatalk GitHub repo, make sure you have Git installed, then
clone the source tree.

git clone https://github.com/netatalk/netatalk.git      # clone the repository
cd netatalk                                             # change to the repo directory

Install software dependencies

At this point, you need to install the software dependencies for building and
running Netatalk.

This list is not exhaustive, and you may need to install additional software
depending on your platform and configuration. See the Compilation documentation
for more details.

Required

These are the libraries that are hard requirements for netatalk.

| Package | Details |
| --- | --- |
| bstring | built as subproject when shared library not found |
| iniparser | v3.1 or later |
| libevent | v2.0 or later |
| libgcrypt | v1.2.3 or later |

CNID Backend Requirements

One or more of the below is required to build the respective CNID backend.

| Package | Backend | Details |
| --- | --- | --- |
| Berkeley DB | dbd | v4.6.0 or later (often packaged as bdb or sometimes db) |
| mysql-client OR mariadb-client | mysql |  |
| sqlite3 | sqlite |  |

Required for Build Environment

In order to build netatalk from source code, the following components are
required at the bare minimum.

| Package | Details |
| --- | --- |
| C compiler | clang or gcc are recommended |
| meson | v0.61.2 or later |
| ninja | Often packaged as ninja-build |

Optional Spotlight Support

| Package | Details |
| --- | --- |
| D-Bus | Also used by avahi and afpstats |
| localsearch OR tracker | v3.0 or later |
| talloc |  |
| bison |  |
| flex |  |

Optional Features

| Package | Details |
| --- | --- |
| avahi OR mDNSresponder | For Zeroconf support |
| cmark OR cmark-gfm OR pandoc | For generating documentation |
| cracklib and cracklib dictionary | For password strength check in afppasswd |
| GLib 2 and GIO | For afpstats support |
| Kerberos V | For krbV UAM support |
| libacl | For ACL support |
| libldap | For LDAP support |
| libpam | For PAM support |
| libtirpc OR libquota | For Quota support |
| Perl | For admin scripts |
| po4a | For localization of documentation |
| tcpwrap | For TCP wrapper support |
| UnicodeData.txt | For regenerating Unicode lookup tables |

Build the software

Use the meson command to compile and install Netatalk.

meson setup build                                       # configure the build
meson compile -C build                                  # build Netatalk

# Become root and install

sudo meson install -C build                             # install Netatalk

To uninstall Netatalk:

sudo ninja -C build uninstall                           # uninstall Netatalk

To test (requires the -Dwith-tests=true flag at configure time):

cd build && meson test

Configuration flags

When using Meson, to review the options which Meson chose, run:

meson configure

With additional arguments the meson setup build command can be used to configure
Netatalk according to user preference. All generic options passed to this
command take the form -Doption=value.

For example, to install Netatalk in a specific location:

meson setup build -Dprefix=/tmp/install

By default meson enables all Netatalk features if their dependencies are
available. However, many features can be enabled or disabled at configure time.

If meson cannot find the some required dependencies at configure time then the
user can also specify the path a library if it is installed in an unconventional
location.

Please see meson_options.txt for full details of all Netatalk-specific options,
and the Meson documentation for details of generic Meson options.

See also

The Netatalk manual has further resources to aid building and installation.

  - Installation chapter: detailed descriptions of each dependency
  - Compilation chapter: concrete build steps for each supported operating
    system
