Linux Installation
The NetBird client (agent) allows a peer to join a pre-existing NetBird deployment. If a NetBird deployment is not yet available, there are both managed and self-hosted options available.
Linux Install Script
curl -fsSL https://pkgs.netbird.io/install.sh | sh
Ubuntu/Debian (APT)
- Add the repository:
sudo apt-get update
sudo apt-get install ca-certificates curl gnupg -y
curl -sSL https://pkgs.netbird.io/debian/public.key | sudo gpg --dearmor --output /usr/share/keyrings/netbird-archive-keyring.gpg
echo 'deb [signed-by=/usr/share/keyrings/netbird-archive-keyring.gpg] https://pkgs.netbird.io/debian stable main' | sudo tee /etc/apt/sources.list.d/netbird.list
- Update APT's cache
sudo apt-get update
- Install the package
# for CLI only
sudo apt-get install netbird
# for GUI package
sudo apt-get install netbird-ui
RHEL/Amazon Linux 2 (RPM)
- Add the repository:
sudo tee /etc/yum.repos.d/netbird.repo <<EOF
[netbird]
name=netbird
baseurl=https://pkgs.netbird.io/yum/
enabled=1
gpgcheck=1
gpgkey=https://pkgs.netbird.io/yum/repodata/repomd.xml.key
repo_gpgcheck=1
EOF
- Install the package
# for CLI only
sudo yum install netbird
# for GUI package
sudo yum install libappindicator-gtk3 libappindicator netbird-ui
Fedora/Amazon Linux 2023 (DNF)
- Create the repository file:
sudo tee /etc/yum.repos.d/netbird.repo <<EOF
[netbird]
name=netbird
baseurl=https://pkgs.netbird.io/yum/
enabled=1
gpgcheck=1
gpgkey=https://pkgs.netbird.io/yum/repodata/repomd.xml.key
repo_gpgcheck=1
EOF
- Import the file
#Fedora 40 or earlier/Amazon Linux 2023** (DNF 4)
sudo dnf config-manager --add-repo /etc/yum.repos.d/netbird.repo
#Fedora 41 or later (DNF 5)
sudo dnf config-manager addrepo --from-repofile=/etc/yum.repos.d/netbird.repo
- Install the package
# for CLI only
sudo dnf install netbird
# for GUI package
sudo dnf install libappindicator-gtk3 libappindicator netbird-ui
On some recent releases, the default behaviour for libappindicator was changed, so we need to install gnome-shell-extension-appindicator and enable it:
sudo dnf install gnome-shell-extension-appindicator
sudo gnome-extensions enable appindicatorsupport@rgcjonas.gmail.com
Under X11, you may need to restart GNOME Shell (Alt+F2, r, ⏎) after that. Under Wayland you need to logout and login again.
Fedora Silverblue (Atomic) / Universal Blue (rpm-ostree)
- Create the repository file:
sudo tee /etc/yum.repos.d/netbird.repo <<EOF
[netbird]
name=netbird
baseurl=https://pkgs.netbird.io/yum/
enabled=1
gpgcheck=1
gpgkey=https://pkgs.netbird.io/yum/repodata/repomd.xml.key
repo_gpgcheck=1
EOF
- Install the package
# for CLI only
rpm-ostree install netbird
# for GUI package
rpm-ostree install netbird-ui
# Don't forget to reboot to apply
- Start the service
systemctl enable --now netbird
Fedora Silverblue / Universal Blue / SteamOS / Immutable Distros (Homebrew)
Requires installation of Homebrew, Universal Blue images should have Homebrew preinstalled.
This method does not install the NetBird GUI. It installs the CLI only.
- If NetBird was previously installed with Homebrew, you will need to run:
# Stop and uninstall daemon service:
sudo netbird service stop
sudo netbird service uninstall
# unlink the app
brew unlink netbird
NetBird will copy any existing configuration from the NetBird's default configuration paths to the new default location.
- Install Netbird
brew install netbirdio/tap/netbird
If it gives you an error saying to install Clang, you can install it with
brew install llvm
If that still doesn't work after that, try restarting your terminal to update the path.
- Install and start the client daemon service:
sudo /home/linuxbrew/.linuxbrew/bin/netbird service install
sudo /home/linuxbrew/.linuxbrew/bin/netbird service start
You may need to adjust this command if you are not using the default /home/linuxbrew/.linuxbrew prefix for your Homebrew install.
On Fedora-based systems including Universal Blue, SELinux may block NetBird from running due to homebrew installing it in ~/linuxbrew.
You can fix this by running
sudo semanage fcontext -a -t bin_t \
'/home/linuxbrew/\.linuxbrew/Cellar/netbird/[^/]+/bin/netbird'
sudo restorecon -Rv /home/linuxbrew/.linuxbrew/Cellar/netbird
sudo systemctl restart netbird
If your Homebrew prefix is set to something other than /home/linuxbrew/.linuxbrew, you may need to adjust those commands to match.
You can verify that the NetBird service is running properly before and after making these changes by running:
sudo systemctl status netbird
Fedora Silverblue / Universal Blue / SteamOS / Immutable Distros (Distrobox)
Requires installation of Distrobox, Universal Blue images should have Distrobox preinstalled.
You will also need to maintain and update Debian inside the Distrobox container.
- Create a distrobox container
distrobox create netbird --init --image debian:13 -a "--cap-add=NET_ADMIN" --additional-packages systemd --root
- Install inside the container
distrobox enter --root netbird
curl -fsSL https://pkgs.netbird.io/install.sh | sh
- Export the Netbird binary to the host
#from inside the container
distrobox-export -b /usr/bin/netbird
openSUSE (zypper)
- Add the repository:
sudo zypper addrepo https://pkgs.netbird.io/yum/ netbird
- Install the package / GPG key
- Key Fingerprint:
AA9C 09AA 9DEA 2F58 112B 40DF DFFE AB2F D267 A61F - Key ID:
DFFEAB2FD267A61F - Email:
dev@netbird.io
# MicroOS (immutable OS with selinux)
transactional-update pkg in netbird
reboot
# Tumbleweed / Leap
zypper in netbird
NixOS 22.11+/unstable
- Edit your
configuration.nix
{ config, pkgs, ... }:
{
services.netbird.enable = true; # for netbird service & CLI
environment.systemPackages = [ pkgs.netbird-ui ]; # for GUI
}
- Build and apply new configuration
sudo nixos-rebuild switch
Binary Install
Installation from binary (CLI only)
- Checkout NetBird releases
- Download the latest release:
curl -L -o ./netbird_<VERSION>.tar.gz https://github.com/netbirdio/netbird/releases/download/v<VERSION>/netbird_<VERSION>_<OS>_<Arch>.tar.gz
You need to replace some variables from the URL above:
- Replace VERSION with the latest released version.
- Replace OS with "linux", "darwin" for MacOS or "windows"
- Replace Arch with your target system CPU architecture
- Decompress
tar xzf ./netbird_<VERSION>.tar.gz
sudo mv netbird /usr/bin/netbird
sudo chown root:root /usr/bin/netbird
sudo chmod +x /usr/bin/netbird
After that you may need to add /usr/bin in your PATH environment variable:
export PATH=$PATH:/usr/bin
- Install and run the service
sudo netbird service install
sudo netbird service start
Updating
If your NetBird client was installed through a package manager, use that to update. If you used the one-command script to install, you can follow this to update:
netbird down
curl -fsSLO https://pkgs.netbird.io/install.sh
chmod +x install.sh
./install.sh --update
netbird up
Running NetBird with SSO Login
Desktop UI Application
If you installed the Desktop UI client, you can launch it and click on Connect.
It will open your browser, and you will be prompt for email and password. Follow the instructions.

CLI
Alternatively, you could use command line. Simply run
netbird up
It will open your browser, and you will be prompt for email and password. Follow the instructions.

Check connection status:
netbird status
Running NetBird with a Setup Key
In case you are activating a server peer, you can use a setup key as described in the steps below.
This is especially helpful when you are running multiple server instances with infrastructure-as-code tools like ansible and terraform.
- Login to the Management Service. You need to have a
setup keyin hand (see setup keys).
netbird up --setup-key <SETUP KEY>
Alternatively, if you are hosting your own Management Service provide --management-url property pointing to your Management Service:
netbird up --setup-key <SETUP KEY> --management-url http://localhost:33073
You could also omit the
--setup-keyproperty. In this case, the tool will prompt for the key.
- Check connection status:
netbird status
- Check your IP:
ip addr show wt0

