我在同一行中有以下文件,其中包含服务器的 fqdn 和该服务器的用户。 猫服务器.txt
server1 user1 \n
server2 user2 \n
server3 user3 \n
我正在编写一个 shell 脚本,我可以一次使用一台服务器来执行 ssh 并在那里执行一些命令,然后移动到下一个服务器。例如,ssh 到 server1 和 sudo 到 user1 并执行这些操作,而不是移动到 server2。 所以我写在下面并尝试调整但没有找到解决方法。它不工作。请帮忙。
ROOT_PATH=/home
SERVERS_FILE=servers.txt
while IFS= read -r line; do
server=`cut -d' ' -f1 $line`
user=`cut -d' ' -f2 $line`
echo $server ::: $user
echo "grep -rw lookeupword $ROOT_PATH/$user" | ssh $server "sudo -iu $user bash"
done <<< "$SERVERS_FILE"
答案 0 :(得分:0)
这会奏效。
#!/usr/bin/env bash
ROOT_PATH=/home
SERVERS_FILE=servers.txt
while IFS= read -r line; do
server=$(echo -n ${line} | awk '{print $1}')
user=$(echo -n ${line} | awk '{print $2}')
echo $server ::: $user
#echo "grep -rw lookeupword $ROOT_PATH/$user" | ssh $server "sudo -iu $user bash"
done < "$SERVERS_FILE"
答案 1 :(得分:0)
如果您不介意使用单衬,这里是一个简单的
首先为您拥有的每个 .ssh/config
创建 Host
文件和设置配置。这是我的(部分)
Host docker
HostName X.X.X.X
port XXXX
user root
Host nginx
HostName X.X.X.X
port XXXX
user root
Host dw
HostName X.X.X.X
port XXXX
user root
因此可以在没有密码的情况下 ssh(ing) 到 docker、nginx、dw(使用公钥/私钥)。
第二次循环遍历您拥有或想要运行命令的 Host
:
xargs -I xxx ssh xxx ip -br a < hosts
这是一个简单的截图: