Self-Host Tailscale dengan Headscale di NAT VPS


NATVPS.id – Anda dapat meng-hosting server Tailscale Anda sendiri menggunakan Headscale. Menggunakan Headscale menghindari informasi mengenai jaringan (seperti node, registrasi perangkat, dan akun) dikirim ke server luar, memberikan Anda kendali penuh terhadap data Anda. Self-hosting Headscale juga mengizinkan Anda untuk memasang autentikasi custom berbasis OpenID Connect (OIDC). Serta, Anda tidak terikat dengan Tailscale karena control serverdikelola oleh Anda sendiri.

Artikel ini membahas mengenai langkah-langkah install Headscale + Headscale-UI di NAT VPS menggunakan Docker, beserta konfigurasi NGINX untuk reverse-proxy. Artikel ini menggunakan Ubuntu 22.04 sebagai acuan, namun Anda dapat menggunakan distribusi lain seperti Debian dan CentOS. Pastikan OS yang digunakan mendukung Docker.

Konfigurasi Port Forwarding

Mengingat kita menggunakan NAT, kita perlu menambahkan 2 konfigurasi port forwarding pada panel Virtualizor (atau panel VPS lain sesuai provider), yaitu port forwarding HTTP dan HTTPS untuk domain Headscale.

Sebagai contoh, pada artikel ini akan menggunakan domain hs.tutorial.mdinata.my.id untuk mengakses Headscale. Anda bebas mengganti domain sesuai pilihan Anda. Catat port dan domain ini, karena kita akan menggunakannya lagi pada proses instalasi.

blank

Jangan lupa untuk menambahkan DNS record yang menuju ke IP publik NAT VPS Anda, seperti ini:

blank

Install Docker

Pertama, Install curl menggunakan perintah:

apt update && apt install curl -y

blank

Kemudian, jalankan script instalasi otomatis dari Docker dengan memasukkan:

curl -fsSL get.docker.com | sh

Tunggu hingga proses instalasi selesai.

blank

Install Headscale

Sebelum menginstal, kita perlu mengecek versi terbaru dari Headscale.

Buka https://github.com/juanfont/headscale/releases/latest, kemudian cek versi terbarunya. Saat artikel ini ditulis, versi terbarunya adalah 0.26.1 (tanpa huruf v.)

blank

Kemudian, masukkan perintah berikut untuk memulai instalasi Headscale:

HEADSCALE_VERSION="0.26.1" # Ganti dengan versi terbaru Headscale yang tersedia
 HEADSCALE_ARCH="amd64"
 
 wget --output-document=headscale.deb " 
 sudo apt install ./headscale.deb

Ganti 0.26.1 di HEADSCALE_VERSION sesuai dengan versi terbaru dari Headscale.

Tunggu hingga instalasi selesai.

blank

Buka file konfigurasi Headscale dengan nano:

apt install nano -y # Jika belum
 nano /etc/headscale/config.yaml

blank

Pada bagian server_url, ubah ke domain yang Anda ingin gunakan untuk mengakses Headscale.

blank

Simpan file tersebut dengan Ctrl-X, y, kemudian Enter.

Aktifkan Headscale dengan perintah:

systemctl enable --now headscale

blank

Install Headscale-UI

Headscale tidak menyediakan antarmuka web untuk mengatur konfigurasinya. Kita dapat menggunakan aplikasi pihak ketiga seperti Headscale-UI untuk mengelola Headscale.

Jalankan peirntah berikut untuk menjalankan Headscale-UI:

docker run -d -p 8443:8443 --restart unless-stopped --name headscale-ui ghcr.io/gurucomputing/headscale-ui:latest

Tunggu hingga proses pull selesai.

blank

Setup NGINX Reverse-Proxy

H
 E
 ADSCALE_VERSION="0.26.1"
 HEADSCALE_ARCH="amd64"
 
 wget --output-document=headscale.deb " 
 sudo apt install ./headscale.deb

Agar kita dapat mengakses Headscale melalui domain seperti hs.tutorial.mdinata.my.id, kita dapat menggunakan reverse proxy seperti NGINX.

Pertama, install NGINX melalui perintah:

# Hapus Apache2 dan pendukungnya (biasanya terpasang secara bawaan di VPS OpenVZ)
 apt purge apache2* -y
 
 # Install NGINX
 apt install nginx -y

blank

Buat konfigurasi host baru khusus untuk Headscale:

nano /etc/nginx/sites-available/headscale

Kemudian tempelkan konfigurasi berikut:

# # Reference:
 # - # - 
 map $http_upgrade $connection_upgrade {
 default upgrade;
 '' close;
 }
 
 server {
 listen 80;
 listen [::]:80;
 server_name hs.tutorial.mdinata.my.id;
 
 # Headscale
 location / {
 proxy_pass proxy_http_version 1.1;
 proxy_set_header Upgrade $http_upgrade;
 proxy_set_header Connection $connection_upgrade;
 proxy_set_header Host $server_name;
 proxy_redirect http:// proxy_buffering off;
 proxy_set_header X-Real-IP $remote_addr;
 proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
 proxy_set_header X-Forwarded-Proto $scheme;
 add_header Strict-Transport-Security "max-age=15552000; includeSubDomains" always;
 }
 
 # Headscale-UI
 location /web/ {
 proxy_pass proxy_http_version 1.1;
 proxy_set_header Host $server_name;
 proxy_buffering off;
 proxy_set_header X-Real-IP $remote_addr;
 proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
 proxy_set_header X-Forwarded-Proto $http_x_forwarded_proto;
 }
 }

Sesuaikan hs.tutorial.mdinata.my.id dengan domain Anda.

blank

Aktifkan konfigurasi tersebut dengan:

ln -sf /etc/nginx/sites-available/headscale /etc/nginx/sites-enabled/headscale
 
 # Restart NGINX
 systemctl restart nginx

blank

Generate Sertifikat SSL (Let’s Encrypt)

Agar domain kita dapat diakses melalui HTTPS, kita perlu membuat sertifikat SSL. Kita dapat menggunakan sertifikat SSL gratis dari Let’s Encrypt melalui Certbot.

Install Certbot dan plugin NGINX nya menggunakan perintah:

apt install python3-certbot python3-certbot-nginx

blank

Lalu, generate sertifikat melalui Certbot dengan perintah

certbot --nginx -d hs.tutorial.mdinata.my.id

Ganti hs.tutorial.mdinata.my.id dengan domain Anda.

blank

Selamat! Domain Anda saat ini dapat diakses melalui koneksi aman HTTPS.

Konfigurasi Headscale-UI

Dashboard Headscale-UI dapat diakses di  headscale>/web. Contoh: https://hs.tutorial.mdinata.my.id/web/.

blank

Kita perlu mengatur URL Headscale kita sebelum dapat menggunakan Headscale-UI.

Pergi ke tab Settings.

blank

Pada bagian Server Settings,

  • Headscale URL: URL Headscale Anda
  • Headscale API Key: API key untuk autentikasi dnegan Headscale

Untuk membuat API key, login ke NAT VPS, lalu ketikan:

headscale api create

blank

Â

blank

Menambahkan User

Anda perlu menambahkan user yang akan digunakan untuk login ke server Headscale dari perangkat client.

Masuk ke tab User View.

blank

Klik New User, kemudian masukkan username bebas.

Â

blank

Menambahkan Device

Untuk menambahkan device dan menghubungkannya ke server Headscale, kita perlu melakukan login ulang dengan alamat server yang diarahkan ke server kita.

1. Windows

Untuk perangkat Windows, buka Terminal/Powershell, kemudian ketikkan:

tailscale login --login-server headscale>

blank

Buka alamat URL yang muncul. Anda akan mendapatkan command untuk mengautentikasi perangkat.

blank

Masukkan perintah tersebut pada NAT VPS. Jangan lupa untuk mengganti USERNAME dengan username Headscale yang telah Anda buat.

blank

Jika sukses, Tailscale di perangkat Windows akan tersambung ke server Headscale Anda.

Penutup

Demikianlah artikel ini mengenai langkah-langkah install Headscale di NAT VPS. Jika bingung atau ragu, jangan sungkan untuk bertanya di grup Telegram @IPv6Indonesia. Terima kasih!



Hiburan

Berita Olahraga

News

Berita Terkini

Berita Terbaru

Berita Teknologi

Seputar Teknologi

Drama Korea

Resep Masakan

Pendidikan

Berita Terbaru

Berita Terbaru

Berita Terbaru

Lifestyle

Leave a Reply

Your email address will not be published. Required fields are marked *