Official releases¶
Official releases for headscale are available as binaries for various platforms and DEB packages for Debian and Ubuntu. Both are available on the GitHub releases page.
Using packages for Debian/Ubuntu (recommended)¶
It is recommended to use our DEB packages to install headscale on a Debian based system as those packages configure a user to run headscale, provide a default configuration and ship with a systemd service file. Supported distributions are Ubuntu 20.04 or newer, Debian 11 or newer.
-
Download the latest headscale package for your platform (
.deb
for Ubuntu and Debian).HEADSCALE_VERSION="" # See above URL for latest version, e.g. "X.Y.Z" (NOTE: do not add the "v" prefix!) HEADSCALE_ARCH="" # Your system architecture, e.g. "amd64" wget --output-document=headscale.deb \ "https://github.com/juanfont/headscale/releases/download/v${HEADSCALE_VERSION}/headscale_${HEADSCALE_VERSION}_linux_${HEADSCALE_ARCH}.deb"
-
Install headscale:
-
Enable and start the headscale service:
-
Verify that headscale is running as intended:
Using standalone binaries (advanced)¶
Advanced
This installation method is considered advanced as one needs to take care of the headscale user and the systemd service themselves. If possible, use the DEB packages or a community package instead.
This section describes the installation of headscale according to the Requirements and assumptions. Headscale is run by a dedicated user and the service itself is managed by systemd.
-
Download the latest
headscale
binary from GitHub's release page: -
Make
headscale
executable: -
Add a dedicated user to run headscale:
-
Download the example configuration for your chosen version and save it as:
/etc/headscale/config.yaml
. Adjust the configuration to suit your local environment. See Configuration for details. -
Copy headscale's systemd service file to
/etc/systemd/system/headscale.service
and adjust it to suit your local setup. The following parameters likely need to be modified:ExecStart
,WorkingDirectory
,ReadWritePaths
. -
In
/etc/headscale/config.yaml
, override the defaultheadscale
unix socket with a path that is writable by theheadscale
user or group: -
Reload systemd to load the new configuration file:
-
Enable and start the new headscale service:
-
Verify that headscale is running as intended: