运维开发网

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

运维开发网 https://www.qedev.com 2020-05-17 15:01 出处:网络
我想创建一个 Linux shell(bash-)脚本,它创建一个SSH隧道,运行一个使用该隧道的本地命令,最后关闭隧道和周围的SSH连接.
我想创建一个 Linux shell(bash-)脚本,它创建一个SSH隧道,运行一个使用该隧道的本地命令,最后关闭隧道和周围的SSH连接.

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

ssh remoteserver -L 4444:targetserver:5555

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

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

你可以尝试类似的东西

TIMEOUT=60 # seconds
ssh remoteserver -L 4444:targetserver:5555 sleep $TIMEOUT &
localclient --port 4444

$TIMEOUT秒后隧道将自动关闭.请注意,使用&仅适用于无密码连接.否则,您需要使用SSH的-f标志.

或者,

ssh -N remoteserver -L 4444:targetserver:5555 &
sshpid=$!
localclient --port 4444
kill $sshpid

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

0

精彩评论

暂无评论...
验证码 换一张
取 消