rem Open tunnel in the background
start plink.exe -ssh [username]@[hostname] -L 3307:127.0.0.1:3306 -i "[SSH
key]" -N
rem Wait a second to let Plink establish the tunnel
timeout /t 1
rem Run the task using the tunnel
"C:\Program Files\R\R-3.2.1\bin\x64\R.exe" CMD BATCH qidash.R
rem Kill the tunnel
taskkill /im plink.exe
ssh user@host <<'ENDSSH'
#commands to run on remote host
ENDSSH
这也可以与su和需要用户输入的命令一起使用 . (注意 ' 逃脱了heredoc)
编辑:由于这个答案不断得到流量,我会添加更多的信息到这个heredoc的精彩使用:
您可以使用此语法嵌套命令,这就是嵌套似乎工作的唯一方式(以理智的方式)
ssh user@host <<'ENDSSH'
#commands to run on remote host
ssh user@host2 <<'END2'
# Another bunch of commands on another host
wall <<'ENDWALL'
Error: Out of cheese
ENDWALL
ftp ftp.secureftp-test.com <<'ENDFTP'
test
test
ls
ENDFTP
END2
ENDSSH
ssh user@host <<-'ENDSSH'
#commands to run on remote host
ssh user@host2 <<-'END2'
# Another bunch of commands on another host
wall <<-'ENDWALL'
Error: Out of cheese
ENDWALL
ftp ftp.secureftp-test.com <<-'ENDFTP'
test
test
ls
ENDFTP
END2
ENDSSH
13 回答
我用这个在远程机器上运行shell脚本(在/ bin / bash上测试):
假设您想要从“本地”机器自动执行此操作,而无需手动登录“远程”机器,您应该查看一个名为Expect的TCL扩展,它专为这种情况而设计 . 它的主页下面看起来有点蹩脚,但不要让它劝阻你;我还提供了一个用于通过SSH登录/交互的脚本的链接 .
http://expect.nist.gov/
http://bash.cyberciti.biz/security/expect-ssh-login-script/
尝试运行
ssh user@remote sh ./script.unx
.这个bash脚本执行ssh到目标远程机器,并在远程机器上运行一些命令,不要忘记在运行之前安装expect(在mac
brew install expect
上)如果你想执行这样的命令
temp=
ls -aecho $temp
命令``会导致错误 .下面的命令将解决这个问题
ssh user@host ''' temp=
ls -aecho $temp '''
首先,使用scp将脚本复制到Machine B.
然后,只需运行脚本
如果您已为脚本提供了可执行权限,则此方法将起作用 .
另外,如果要从目标主机中选择它们,请不要忘记转义变量 .
这让我过去了 .
例如:
打印出/ home / user2
而
打印/ home / user
另一个例子:
正确打印出“你好” .
如果您尝试使用
plink
或ssh
在远程Linux机器上运行脚本,则此处(https://stackoverflow.com/a/2732991/4752883)的答案非常有用 . 如果脚本在linux
上有多行,它将起作用 .但是,如果您尝试运行位于本地
linux/windows
计算机上的批处理脚本,并且您的远程计算机是Windows
,并且它包含多行使用plink root@MachineB -m local_script.bat
不会工作 .
只会执行脚本的第一行 . 这可能是
plink
的限制 .解决方案1:
要运行多行批处理脚本(特别是如果它相对简单,包含几行):
如果您的原始批处理脚本如下所示
您可以使用"&&"文件中的"&&"分隔符将行组合在一起,如下所示:https://stackoverflow.com/a/8055390/4752883:
在此更改之后,您可以按照@ JasonR.Coombs所指示的那样运行脚本:https://stackoverflow.com/a/2732991/4752883:
解决方案2:
如果批处理脚本相对复杂,最好使用封装plink命令的批处理脚本,以及@Martin https://stackoverflow.com/a/32196999/4752883指出的以下内容:
这将提示您输入密码,除非您已将hostA用户的公钥复制到用户.ssh目录主页上的authorized_keys文件中 . 这将允许无密码身份验证(如果在ssh服务器的配置上被接受为auth方法)
这是一个老问题,杰森的答案很好,但我想补充一点:
这也可以与su和需要用户输入的命令一起使用 . (注意
'
逃脱了heredoc)编辑:由于这个答案不断得到流量,我会添加更多的信息到这个heredoc的精彩使用:
您可以使用此语法嵌套命令,这就是嵌套似乎工作的唯一方式(以理智的方式)
你实际上可以与telnet,ftp等服务进行对话 . 但是请记住,heredoc只是将stdin作为文本发送,它不会等待行之间的响应
编辑:我发现如果你使用
<<-END
,你可以缩进内部!(我认为这应该有效)
另见http://tldp.org/LDP/abs/html/here-docs.html
如果计算机A是Windows框,则可以将Plink(PuTTY的一部分)与-m参数一起使用,它将在远程服务器上执行本地脚本 .
如果机器A是基于Unix的系统,您可以使用:
您不必将脚本复制到远程服务器以运行它 .
这是YarekT将内联远程命令与从本地机器传递到远程主机的ENV变量结合起来的答案的扩展,因此您可以在远程端参数化脚本:
我发现这一点非常有用,因为它保存在一个脚本中,因此它非常易读且易于维护 .
为什么会这样 . ssh支持以下语法:
在bash中,我们可以指定在单行上运行命令之前定义的环境变量,如下所示:
这使得定义变得容易运行命令之前的变量 . 在这种情况下,echo是我们正在运行的命令 . echo之前的所有内容都定义了环境变量
因此,我们结合这两个功能和YarekT的答案得到:
在这种情况下,我们将ARG1和ARG2设置为本地值 . 将user @ host之后的所有内容作为remote_command发送 . 当远程机器执行命令时,ARG1和ARG2被设置为本地值,这要归功于在远程服务器上定义环境变量的本地命令行评估,然后使用这些变量执行bash -s命令 . 瞧 .
我已经开始使用Fabric进行更复杂的操作 . Fabric需要Python和其他几个依赖项,但仅限于客户端计算机上 . 服务器只需要一个ssh服务器 . 我发现这个工具比传递给SSH的shell脚本更强大,值得设置的麻烦(特别是如果你喜欢用Python编程) . Fabric处理在多个主机(或某些角色的主机)上运行脚本,有助于促进幂等操作(例如向配置脚本添加一行,但如果它已经存在则不行),并允许构造更复杂的逻辑(例如Python)语言可以提供) .