ssh登录远程主机,让远程主机执行脚本文件,并传参
该问题就是:
用下面这条命令时需要向ssh2.sh传入参数,该怎么办
cat ssh2.sh | ssh hadoop102 "bash -s"
cat ssh2.sh | ssh hadoop102 “bash -s” 用该命令时需要向ssh2.sh传入参数,该怎么办
方法一
如果只考虑向ssh2.sh传入参数:
可以在命令行中使用管道符号和echo命令将参数传递给ssh2.sh脚本,然后使用ssh命令将脚本传输到远程服务器并执行。具体的实现方式如下:
echo "param1 param2" | ssh hadoop102 "bash -s" < ssh2.sh
在上面的命令中,使用echo命令将参数"param1"和"param2"传递给ssh2.sh脚本,然后使用ssh命令将脚本传输到远程服务器hadoop102并执行。在脚本中,可以使用$1和$2等变量来获取传递的参数。
例如,如果ssh2.sh脚本内容如下:
#!/bin/bash
echo "The first parameter is: $1"
echo "The second parameter is: $2"
那么在执行上面的命令时,远程服务器会输出以下内容:
The first parameter is: param1
The second parameter is: param2
总之,通过使用管道符号和echo命令将参数传递给脚本,并在脚本中使用$1、$2等变量来获取参数,可以实现在执行远程脚本时传递参数的功能。
方法二
在命令行中直接传入参数:
cat ssh2.sh | ssh hadoop102 "bash -s" arg1 arg2 arg3
在这个例子中,arg1、arg2和arg3是传递给ssh2.sh脚本的参数。
在ssh2.sh脚本中使用$1、$2、$3等变量来获取传入的参数