IPTables Reroute SSH based on Connection string?

Posted by senrabdet on Server Fault See other posts from Server Fault or by senrabdet
Published on 2012-11-03T13:52:52Z Indexed on 2012/11/03 17:06 UTC
Read the original article Hit count: 183

Filed under:
|
|

We are using a cloud server (Debian Squeeze) where public ports on a public IP route traffic to internal servers. We are looking for a way to use IPTables and ssh where based on some part of the ssh connection string (or something along these lines) iptables will reroute the ssh connection to the "right" internal server. This would allow us to use one common public port, and then re-route ssh connections to individual servers.

So, for example we hope to do something like the following:

  • user issues ssh connection (public key encryption) such as ssh -X -v -p xxx [email protected] but maybe adds something into the string for iptables to use
  • iptables uses some part of that string or some means to re-route the connection to an internal server using something like

    iptables -t nat -A PREROUTING ! -s xxx.xxx.xxx.0/24 -m tcp -p tcp --dport $EXTPORT -j DNAT --to-destination $HOST:$INTPORT
    

    ....where $HOST is the internal ip of a server, $EXTPORT is the common public facing port and $INTPORT is the internal server port.

It appears that the "string" aspect of iptables does not do what we want.

We can currently route based on the IP table syntax we're using, but rely on having a separate public port for each server and are hoping to use one common public port and then re-route to specific internal servers based on some part of the ssh connection string or some other means.

Any suggestions? Thanks!

© Server Fault or respective owner

Related posts about ssh

Related posts about iptables