在Bash脚本中,尝试将本地变量传递给SSH,然后执行其他命令

问题描述

#!/bin/bash

count2=1
declare -a input
input=( "$@" )

echo " "
echo " Hostname passed by user is " ${input[0]}
HOST="${input[0]}"

sshpass -p '<pass>' ssh -o StrictHostKeyChecking=no user@$HOST /bin/bash  << ENDSSH

echo " Connected "
echo $count2
echo $input
pwd
echo $count2: ${input[$count2]}
nic=${input[$count2]}
echo $nic
echo $(ethtool "${nic}" |& grep 'Link' | awk '{print $3}')

ENDSSH

因此,实际上想将变量'count2''input'传递给远程SSH并执行。 但不幸的是,它没有通过。 SSH之后没有回显任何内容。 需要帮助。! 我在服务器中安装了sshpass。

代码输出

[user@l07 ~]$ ./check.sh <hostname> eno6

 Hostname passed by user is  <hostname>
 Connected


在SSH之后,它仅回显“已连接”。我不确定为什么$count2$input没有回显。 我对反冲'\$count2'感到厌倦,但这也不起作用。即使使用ENDSSH的带引号和取消引号,也尝试了所有可能的组合。请帮助

任何帮助将不胜感激!

解决方法

您必须在此处添加转义符(... echo \$nic ... echo \$(ethtool "\${nic}" |& grep 'Link' | awk '{print \$3}') ... ):

echo

但是为什么要回声呢?不使用... ethtool "\${nic}" |& grep -i 'Link' | awk '{print \$3}' ...

即可尝试
import os
import glob


for pkg_name in glob.glob('../../pkg*'):
    if os.path.isdir(pkg_name):
          os.remove(pkg_name + "/dev-tools/emk-test/ro_template.bin")
,

您基本上想向远程bash提供要执行的HERE文档。这很棘手,因为您需要先“撰写”本文档的全文,然后才能将其提供给ssh。因此,我将任务分为两个部分:

  1. 创建HERE文档
  2. 在ssh上运行

这使得调试在步骤1和步骤2之间输出文档以及直观检查其内容的正确性变得很容易。不要忘记,一旦此代码在远程主机上运行,​​它将无法再访问任何变量,除非您已使用ssh提供的方法将它们“提升”到了远程端。

因此,您可以这样开始:

# Create the parameters you want to use
nic=${input[$count2]}

# Create a variable holding the content of the remote script,# which interpolates your parameters
read -r -d '' remote_script << ENDSSH
echo "Connected to host \$(hostname)"
echo "Running bash version: \$BASH_VERSION"
....
ethtool "$nic" |& grep Link | awk '{ print $3 }'
ENDSSH

# Print your script for verification
echo "$remote_script"

# Submit it to the host
sshpass -p '<pass>' ssh -o StrictHostKeyChecking=no "user@$HOST" /bin/bash <<<"$remote_script"
,
#!/bin/bash

count2=1
declare -a input
input=( "$@" )

echo " Hostname passed by user is " "${input[0]}"
HOST="${input[0]}"

while [ $# -gt $count2 ]
do

    sed -i 's/VALUE/'"${input[$count2]}"'/g' ./check.sh 

sshpass -p '<pass>' scp ./check.sh user@"$HOST":/home/user/check.sh
sshpass -p '<pass>' ssh -o StrictHostKeyChecking=no user@"$HOST" "sh /home/user/check.sh && rm -rf /home/user/check.sh"
 
sed -i 's/'"${input[$count2]}"'/VALUE/g' ./check.sh
((count2++))

done

找到了该问题的另一种解决方案:它现在对我有用!!!!

我写了我的整个逻辑,需要在check.sh文件中远程执行,现在将用户输入替换或存储到该check.sh文件中,然后通过scp将该文件复制到远程服务器中并通过它执行在远程执行成功执行后,从远程服务器上删除此文件,然后在ssh之后,再次使用sed命令将用户输入更改为本地服务器中的原始值。

将此作为动态脚本,以用于多个服务器。