Pre-built Binaries

Ready to use binaries for all major platforms

Just head to the releases page and download the latest version for you platform. There are builds available for Linux (Intel and ARM, 32 and 64 bits), Windows (Intel 32 and 64 bits) and macOS (Intel 64 bits).

For Raspberry Pi, use a suitable Linux ARM builds. Tested with Raspbian

Remember to install ffmpeg in your system, a requirement for Navidrome to work properly. You may find the latest static build for your platform here:

If you have any issues with these binaries, or need a binary for a different platform, please open an issue

Arch Linux Packages

You can install Navidrome via the navidrome-bin package in the AUR. Alternatively, you can install using the navidrome-git package which will compile Navidrome from source.

Ubuntu Installation

The following steps have been tested on Ubuntu 18.04 and should work on all version 16.04 and above as well as other Debian based distros. Throughout these instructions the commands will have placeholders for the user (<user>) and group (<group>) you want to run Navidrome under and the music folder path (<library_path>). If you are using an existing media library ensure the user has permissions to the media library.

Update and Install Prerequisites

Ensure your system is up to date and install ffmpeg.

sudo apt update
sudo apt upgrade
sudo apt install vim ffmpeg

Create Directory Structure

Create a directory to store the Navidrome executable and a working directory with the proper permissions.

sudo install -d -o <user> -g <group> /opt/navidrome
sudo install -d -o <user> -g <group> /var/lib/navidrome

Get Navidrome

Download the latest release from the releases page, extract the contents to the executable directory, and set the permissions for the files. (Replace the URL below with the one from the releases page):

wget -O Navidrome.tar.gz
sudo tar -xvzf Navidrome.tar.gz -C /opt/navidrome/
sudo chown -R <user>:<group> /opt/navidrome

Create Configuration File

In the working directory, /var/lib/navidrome create a new file named navidrome.toml with the following settings.

MusicFolder = "<library_path>"

For additional configuration options see the configuration options page.

Create a Systemd Unit

Create a new file under /etc/systemd/system/ named navidrome.service with the following data.

Description=Navidrome Music Server and Streamer compatible with Subsonic/Airsonic


ExecStart=/opt/navidrome/navidrome --configfile "/var/lib/navidrome/navidrome.toml"

# See
RestrictAddressFamilies=AF_UNIX AF_INET AF_INET6
SystemCallFilter=~@clock @debug @module @mount @obsolete @reboot @setuid @swap

# You can uncomment the following line if you're not using the jukebox This
# will prevent navidrome from accessing any real (physical) devices

# You can change the following line to `strict` instead of `full` if you don't
# want navidrome to be able to write anything on your filesystem outside of
# /var/lib/navidrome.

# You can comment the following line if you don't have any media in /home/*.
# This will prevent navidrome from ever reading/writing anything there.

Start the Navidrome Service

Relaod the service daemon, start the newly create service, and verify it has started correctly.

sudo systemctl daemon-reload
sudo systemctl start navidrome.service
sudo systemctl status navidrome.service

If the service has started correctly verify you can access http://localhost:4533

Start Navidrome on Startup

sudo systemctl enable navidrome.service

Last modified October 5, 2020: Add Scanner.Extactor config option (c4f896e)