Skip to content

Installing Tailscale through Entware

ColinTaylorUK edited this page Nov 1, 2024 · 13 revisions

Introduction

Tailscale is a VPN service that makes the devices and applications you own accessible anywhere in the world, securely and effortlessly. It enables encrypted point-to-point connections using the open source WireGuard protocol, which means only devices on your private network can communicate with each other.

https://tailscale.com/kb/1151/what-is-tailscale

Prerequisites

This installation guide assumes you are already familiar with the general operation of Tailscale. Extensive documentation is available on the Tailscale website and it is not the purpose of this guide to replicate it here.

You must already have a working installation of Entware on your router.

You also need to have created a Tailscale account to use with your devices. https://tailscale.com/kb/1017/install#step-1-sign-up-for-an-account

Installation

1. Install Tailscale

Install the Tailscale Entware package.

# opkg install tailscale
Installing tailscale (1.58.2-1) to root...
Downloading https://bin.entware.net/aarch64-k3.10/tailscale_1.58.2-1_aarch64-3.10.ipk
Installing ca-bundle (20230311-1) to root...
Downloading https://bin.entware.net/aarch64-k3.10/ca-bundle_20230311-1_all.ipk
Configuring ca-bundle.
Configuring tailscale.

N.B. Older routers that use kernel 2.6 (e.g. RT-AC68U) should instead install the tailscale_nohf package.

2. Kernel vs. Userspace Mode

By default Tailscale operates in kernel mode. Kernel mode is more performant than userspace mode but may be incompatible with certain Merlin addons and features. Depending on which mode you choose the following changes are required.

2.1 Kernel Mode

Add/change the following lines in /opt/etc/init.d/S06tailscaled.

PRECMD="modprobe tun"
ARGS="--state=/opt/var/tailscaled.state --statedir=/opt/var/lib/tailscale"
PREARGS="nohup"

Create a /jffs/scripts/firewall-start user script as follows, or add the line to the existing script if you have one. Remember to make the script executable.

#!/bin/sh
if [ -x /opt/bin/tailscale ]; then tailscale down; tailscale up; fi

2.2 Userspace Mode

Change the following lines in /opt/etc/init.d/S06tailscaled.

ARGS="--state=/opt/var/tailscaled.state --statedir=/opt/var/lib/tailscale --tun=userspace-networking"
PREARGS="nohup"

No firewall changes are needed in userspace mode.

3. Start Tailscale

Use the following command to start the Tailscale daemon, or reboot the router.

# /opt/etc/init.d/S06tailscaled start
 Starting tailscaled...              done.

4. Configure Tailscale as an exit node and subnet router

This is a one-time task. If your LAN uses a different IP address or subnet mask change the command below to match your system.

# tailscale up --advertise-exit-node --advertise-routes=192.168.50.0/24

To authenticate, visit:

        https://login.tailscale.com/a/xxxxxxxxxxxxx

Copy your unique authentication URL and paste it into a browser. Connect the device using your Tailscale account.

Find your router's name in the Tailscale Machines list and click on .../Disable key expiry. Now click on .../Edit route settings... and enable Subnet routes and Exit node.

Return to your terminal session and you should see the "Success" message.

Success.

Reconfiguring Tailscale

Tailscale's behaviour can be changed by setting various flags using tailscale up or tailscale set. See the official documentation here:

https://tailscale.com/kb/1241/tailscale-up

https://tailscale.com/kb/1080/cli#set

Examples

Reset tailscale to a standalone device (not advertising itself as an exit node or subnet router):

tailscale up --reset

Tell tailscale to stop advertising itself as an exit node:

tailscale set --advertise-exit-node=false

Many other options are available including LAN to LAN setups but that is beyond the scope of this guide.

Updating Tailscale (or not).

The Tailscale Entware package is periodically updated and can be upgraded just like any other Entware package using opkg upgrade. See Known Issues below.

# opkg update
Downloading https://bin.entware.net/aarch64-k3.10/Packages.gz
Updated list of available packages in /opt/var/opkg-lists/entware

# opkg upgrade
Upgrading tailscale on root from 1.68.2-1 to 1.68.2-3...
Downloading https://bin.entware.net/aarch64-k3.10/tailscale_1.68.2-3_aarch64-3.10.ipk
Configuring tailscale.

# /opt/etc/init.d/S06tailscaled restart
 Shutting down tailscaled...              done.
 Starting tailscaled...              done.

I recommend you don't update Tailscale directly from the Tailscale website using the commands below as it may not be fully compatible with asuswrt-merlin.

# tailscale update
This will update Tailscale from 1.58 to 1.64.0. Continue? [y/n] y
Downloading "https://pkgs.tailscale.com/stable/tailscale_1.64.0_arm64.tgz"
Download size: 25751613
Downloaded 8720/25751613 (0.0%)
Downloaded 25751613/25751613 (100.0%)
Downloading "https://pkgs.tailscale.com/stable/tailscale_1.64.0_arm64.tgz.sig"
Signature OK
Extracting "/root/.cache/tailscale-update/tailscale_1.64.0_arm64.tgz"
Updated /tmp/mnt/TOSHIBA1/entware/bin/tailscale
Updated /tmp/mnt/TOSHIBA1/entware/bin/tailscaled
Tailscale binaries updated successfully.
Please restart tailscaled to finish the update.

# /opt/etc/init.d/S06tailscaled restart
 Shutting down tailscaled...              done.
 Starting tailscaled...              done.

Uninstalling Tailscale

To remove Tailscale from your router run the following commands. If you made changes to /jffs/scripts/firewall-start you should undo that also.

# /opt/etc/init.d/S06tailscaled stop
 Checking tailscaled...              alive.
 Shutting down tailscaled...              done.

# opkg remove tailscale
Removing package tailscale from root...

# rm /opt/var/tailscaled.state

# rm -fr /opt/var/lib/tailscale

Now go to the Tailscale admin console and find the entry for the router. Click on .../Remove... and remove the machine.

Known Issues

  1. Be aware that upgrading the Tailscale Entware package (opkg upgrade) will overwrite any changes made to /opt/etc/init.d/S06tailscaled. Make sure you know what changes you have made so that you can reapply them after the upgrade.
Clone this wiki locally