问题描述
#!/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。因此,我将任务分为两个部分:
- 创建HERE文档
- 在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
命令将用户输入更改为本地服务器中的原始值。
将此作为动态脚本,以用于多个服务器。