When you need to create reverse SSH tunnel from your system/node.
Step-by-step guide
SSH from the destination to the source (with public IP) using the command below:
ssh –f –N –T –R 19999:localhost:22 sourceuser@138.47.99.99 ## '19999' can be any unused port
Now you can SSH from source to destination through SSH tunneling:
ssh localhost -p 19999
- 3rd party servers can also access 192.168.20.55 through Destination (138.47.99.99)
Destination (192.168.20.55) <- |NAT| <- Source (138.47.99.99) <- Bob's serverFrom Example's server:
ssh sourceuser@138.47.99.99
After the successful login to Source:
ssh localhost -p 19999 ## the connection between destination and source must be alive AT ALL TIMES
- Closing SSH tunnel:
- Rebooting system
- Find the process and kill the PID
Remove all SSH sessions, all of them...
sudo killall ssh
Tips:
- you may run a command (e.g. watch, top) on Destination to keep the connection active
- If your system sleeps, it may close the SSH tunnel; article to disable the 'sleep/hibernate' function: Disable Ubuntu sleep timer
Related articles