Skip to main content.

Reverse SSH tunneling

2014-08-27

Live demo in BSD Now Episode 052. | Originally written by TJ for bsdnow.tv | Last updated: 2014/08/27

NOTE: the author/maintainer of the tutorial(s) is no longer with the show, so the information below may be outdated or incorrect.

We've done a number of SSH tutorials in the past, but most of them rely on the fact that you have a certain level of control on the network. In some cases, you need to be able to access a system that's behind a firewall. This guide will show you how to do just that - reversing the connection and accessing an internal system from the outside. The only requirement in this case is that the firewall allows outbound SSH traffic. You'll have to have access to the machine behind the firewall at some point for this to work. The -R switch will play a key role in this (very short) tutorial. Since we'll be reversing the connection, be sure your client system has a publicly-accessible sshd running. On the system behind the firewall, run the following:

$ ssh -fN -R 9000:localhost:22 user@clientip

Replace "clientip" with the IP of your system and "22" with the port on which you run sshd. It's recommended to run that command in tmux so it doesn't get lost. You might want to consider running sshd on port 443, so it looks similar to normal SSL traffic. See our stunnel tutorial for more ideas there. Now move back to the client system, and we'll make the reverse connection like so:

$ ssh -p 9000 user@127.0.0.1

While it may appear to be connecting on the loopback device, it's actually using the already-established connection made by the internal machine. You'll need to use the username and password/key that you normally would for the internal system. Some recommended settings to have in the client's /etc/ssh/sshd_config:

ClientAliveInterval 300
TCPKeepAlive yes

With these, the internal system will send a packet to the client every five minutes to keep the connection from dying due to inactivity. One problem with this setup is, of course, if the first connection dies. Another possible issue is if your client's IP changes. While not much can be done about the first one (aside from maybe a cron job to try and re-establish the connection), there is a good way to handle the second situation. If you use something like SSH chaining, you can leave the internal system connected to a dedicated server whose IP doesn't ever change. From there, connect to the server, then to localhost.

Latest News

New announcement

2017-05-25

We understand that Michael Dexter, Brad Davis, and George Rosamond think there should be more real news....

Two Year Anniversary

2015-08-08

We're quickly approaching our two-year anniversary, which will be on episode 105. To celebrate, we've created a unique t-shirt design, available for purchase until the end of August. Shirts will be shipped out around September 1st. Most of the proceeds will support the show, and specifically allow us to buy...

New discussion segment

2015-01-17

We're thinking about adding a new segment to the show where we discuss a topic that the listeners suggest. It's meant to be informative like a tutorial, but more of a "free discussion" format. If you have any subjects you want us to explore, or even just a good name...

How did you get into BSD?

2014-11-26

We've got a fun idea for the holidays this year: just like we ask during the interviews, we want to hear how all the viewers and listeners first got into BSD. Email us your story, either written or a video version, and we'll read and play some of them for...


Episode 251: Crypto HAMMER

2018-06-20

Direct Download:MP3 AudioVideo This episode was brought to you by Headlines DragonflyBSD: Towards a HAMMER1 master/slave encrypted setup with LUKS I just wanted to share my experience with setting up DragonFly master/slave HAMMER1 PFS's on top of LUKS So after a long time using an Synology for my NFS needs, I...

Episode 250: BSDCan 2018 recap

2018-06-13

Direct Download:MP3 AudioVideo This episode was brought to you by Headlines TrueOS to Focus on Core Operating System The TrueOS Project has some big plans in the works, and we want to take a minute and share them with you. Many have come to know TrueOS as the “graphical FreeBSD” that makes...

Episode 249: Router on a stick

2018-06-06

Direct Download:MP3 AudioVideo This episode was brought to you by Headlines ZFS and DTrace update lands in NetBSD merge a new version of the CDDL dtrace and ZFS code. This changes the upstream vendor from OpenSolaris to FreeBSD, and this version is based on FreeBSD svn r315983. + r315983 is from...

Episode 248: Show me the Mooney

2018-05-30

Direct Download:MP3 AudioVideo This episode was brought to you by Headlines DragonFlyBSD: release52 (w/stable HAMMER2, as default root) DragonflyBSD 5.2.1 was released on May 21, 2018 > Big Ticket items: > Meltdown and Spectre mitigation support Meltdown isolation and spectre mitigation support added. Meltdown mitigation is automatically enabled for all Intel cpus. Spectre mitigation must be enabled...