用于本地(非远程)命令执行的ssh隧道

muf*_*fel 5 linux ssh bash shell

我想创建一个Linux shell(bash-)脚本,它创建一个SSH隧道,运行一个使用该隧道的本地命令,最后关闭隧道和周围的SSH连接.

为了减少解释难度,可以考虑一个名为"remoteserver"的主机的本地SSH配置,其中包含一个没有密码的本地私钥,所以

ssh remoteserver -L 4444:targetserver:5555

将直接打开与远程服务器的连接,并创建从本地端口4444到目标服务器的隧道.并考虑本地命令是什么localclient --port 4444,脚本看起来如何打开隧道,执行本地命令并在本地客户端应用程序完成后关闭隧道?

由于应该可以保持其他并行正在进行的SSH连接,我不想要类似的东西sudo killall ssh.

dam*_*ois 5

你可以尝试类似的东西

TIMEOUT=60 # seconds
ssh remoteserver -L 4444:targetserver:5555 sleep $TIMEOUT &
localclient --port 4444
Run Code Online (Sandbox Code Playgroud)

$ TIMEOUT秒后隧道将自动关闭.请注意,使用&它仅对无密码连接有效.否则,您需要使用-fSSH标志.

或者,

ssh -N remoteserver -L 4444:targetserver:5555 &
sshpid=$!
localclient --port 4444
kill $sshpid
Run Code Online (Sandbox Code Playgroud)

将在localclient执行后立即杀死隧道.请注意,这不适用于-f标志,因为进程双叉.