“TeckMile.com – Elevating Your Skills and Creativity, One Project at a Time.”

Install Tinc Mesh VPN on Linux

In this tutorial, we’ll guide you through the process of setting up a Tinc VPN service with a static IP. For this demonstration, we’ll assume you have one machine in the cloud with a static IP (referred to as ‘your_server’) and another machine (‘your_client’) located behind multiple NAT firewalls. Tinc is a highly versatile mesh VPN that can be used in various configurations, but we’ll use a simple client-server analogy for this tutorial.

Step 1: Update Your System

Before starting, ensure your system is up-to-date by running the following commands:

sudo apt update && sudo apt upgrade

Step 2: Install Tinc

Install Tinc on your system with the following command:

sudo apt install tinc

Step 3: Configure your_server

First, set up the configuration files and directory structure for ‘your_server’:

sudo mkdir -p /etc/tinc/labnet/hosts

sudo nano /etc/tinc/labnet/tinc.conf

Fill in the config file as follows:

Name = your_server

AddressFamily = ipv4

Interface = tun0

Next, create the host configuration file:

sudo nano /etc/tinc/labnet/hosts/your_server

Replace ‘IP_here’ with the actual static IP:

Address = IP_here

Subnet = 10.0.0.1/32

Generate the keys for ‘your_server’:

sudo tincd -n labnet -K4096

Now, create the script to enable the virtual network:

sudo nano /etc/tinc/labnet/tinc-up

Add the following lines:

#!/bin/sh

ip link set $INTERFACE up

ip addr add 10.0.0.1/32 dev $INTERFACE

ip route add 10.0.0.0/24 dev $INTERFACE

Create the script to disable the virtual network:

sudo nano /etc/tinc/labnet/tinc-down

Add the following lines:

#!/bin/sh

ip route del 10.0.0.0/24 dev $INTERFACE

ip addr del 10.0.0.1/32 dev $INTERFACE

ip link set $INTERFACE down

Make the scripts executable:

sudo chmod 755 /etc/tinc/labnet/tinc-*

If you’re using a firewall, allow traffic on port 655:

On a Debian based System:

sudo ufw allow 655

For a RHEL or Rocky Linux System:

sudo firewall-cmd –permanent –zone=public –add-port=655/tcp
sudo firewall-cmd –permanent –zone=public –add-port=655/udp

Please note that you may need to configure firewall rules through your cloud service provider if your machines are hosted on cloud services like AWS.

Step 4: Configure your_client

Repeat the following steps for ‘your_client’ (or additional clients with different subnets):

  1. Create the file structure and configuration files with a unique name, for this example we will use ‘your_client’. be sure to use a unique ip address for the client, e.g. replace 10.0.0.1/32 with 10.0.0.2/32 in the ‘tinc-up’ ‘tinc-down’ ‘tinc.conf’ and ‘/etc/tinc/labnet/hosts/your_clinet’ files.
  2. Generate keys for the client.
  3. Open port 655 if a firewall is used on the client.

Step 5: Distribute Keys

next we need to distribute the keys we generated earlier between the machines, we will use scp (secure copy) to do this

first we will copy the your_server keys to the your_client from the your_client machine

sudo scp userhere@public_ip_here:/etc/tinc/labnet/hosts/your_server /etc/tinc/labnet/hosts/

here we will copy to the your_client keys to your_server, for this example your_client does not have a public ip so we will use the your_client machine for the transfer for simplicity

scp /etc/tinc/labnet/hosts/your_client userhere@public_ip_here:/tmp

then the following command, run from the server_01 machine

sudo mv /tmp/your_client /etc/tinc/labnet/hosts/

Step 6: Test the Connection

Test the connection with:

sudo tincd -n labnet -D -d3

Step 7: Auto-start Tinc VPN

Enable Tinc VPN to start on boot:

sudo systemctl enable tinc@labnet

To disable Tinc VPN from starting on boot, use:

sudo systemctl disable tinc@labnet

Step 8: Multiple Tinc VPNs

You can create multiple Tinc VPNs by creating different directories under /etc/tinc/. Starting multiple Tinc VPNs simultaneously is possible.

To start multiple Tinc networks:

sudo systemctl start tinc@labnet tinc@network2 tinc@network3

The process for setting up additional Tinc clients for a network is straightforward. Ensure each client has a unique IP address, exchange keys, and start the service.


Comments

Leave a Reply

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