Persistent SSH Tunnels: Difference between revisions

From KG7QIN's Wiki
Jump to navigation Jump to search
m (Added category)
Line 8: Line 8:
''Note:  This user does not have a password assigned or a shell.  This will prevent user logins to the system.''
''Note:  This user does not have a password assigned or a shell.  This will prevent user logins to the system.''
<pre>
<pre>
useradd -m -s /bin/false autossh
useradd -m -s /bin/false autossh   # note: you may need to use /usr/sbin/bash on some systems
</pre>
</pre>
Now switch to the user and generate an SSH key:
Now switch to the user and generate an SSH key:

Revision as of 04:56, 18 February 2024

Persistent SSH Tunnels

The following is how to create a persistent SSH Tunnel between two systems. This is handy if you want to secure data flowing across networks, or even setup a tunnel without messing with VPN configuration.

Create User/Generate SSH key

First you will create the user you will use for the tunnel. This will allow you to forward non-privileged ports over 1024.

Note: This user does not have a password assigned or a shell. This will prevent user logins to the system.

useradd -m -s /bin/false autossh   # note: you may need to use /usr/sbin/bash on some systems

Now switch to the user and generate an SSH key:

su -s /bin/bash autossh
cd ~
ssh-keygen -b 4096

Note: Leave password blank

Once done, exit back to your normal user shell

exit

Copy public key to target system

You will need to copy id_rsa.pub file from /home/autossh/.ssh/ to the authorized_keys file on the remote system you want to connect to for the tunnel.

Note: It is recommended that you also create a normal user on the remote system and not use root.

Install autossh

You will need to install the autossh program on the system that will initiate the SSH tunnel. Autossh automatically restarts the SSH tunnel when it exits.

apt-get install autossh

Setup script

Copy the following script, making the necessary changes as specified between the <> and place on the system that will initiate the tunnel (here we will save it as /opt/ssh-tunnel.sh):

#!/bin/sh
#

su -s /bin/sh autossh -c 'autossh -M 0 -N -o "ServerAliveInterval 30" -o "ServerAliveCountMax 3" -o "ExitOnForwardFailure=yes" -f -T -R localhost:<target port>:<local IP or localhost>:<local port> <user>@<domain>'

Parameter Description
localhost localhost or IP address on target system
<target port> port on target system
<local IP or localhost> localhost or IP address on system initiating tunnel
<local port> port on system initiating tunnel
<user@domain> username and domain to use when SSHing to target system

An example of this command is:

su -s /bin/sh autossh -c 'autossh -M 0 -N -o "ServerAliveInterval 30" -o "ServerAliveCountMax 3" -o "ExitOnForwardFailure=yes" -f -T -R localhost:3306:localhost:3306 joe@blow.com'

This would allow the target (remote) system to access the local (system initiating the SSH tunnel) system's MySQL server over the tunnel.

You can also use -L to change the direction of the port forwarding from Remote to Local and have the initiating system forward data over the tunnel the the remote.

Make script executable

Make sure you mark the script as executable with:

chmod +x /opt/ssh-tunnel.sh

Tunnel at startup

To have the tunnel up when the system restarts, choose one of the following methods

rc.local

Add a line to /etc/rc.local that calls the script.

# Start AutoSSH tunnel at boot
/opt/ssh-tunnel.sh

Note: You may have to enable rc.local on Ubuntu and Debian based systems via systemd. Refer to your distributions documentation for information on how to enable it.

systemd

To have the script start at boot with systemd, create the following file and add it to /etc/systemd/system/ssh-tunnel.service

ssh-tunnel.service

[Unit]
Description=AutoSSH Tunnel at boot

[Service]
Type=oneshot
ExecStart=/opt/ssh-tunnel.sh

[Install]
WantedBy=multi-user.target

Enable service

To enable the service to run via systemd run:

systemctl enable ssh-tunnel.service