Files
shell/ssh.sh
2024-03-27 21:07:47 +08:00

71 lines
1.8 KiB
Bash

#!/bin/bash
# 定义颜色
green='\033[0;32m'
none='\033[0m'
# 检查并安装 sshpass
if ! command -v sshpass &> /dev/null; then
echo "sshpass 没有找到,正在尝试安装..."
apt-get update && apt-get install -y sshpass
fi
# 服务器信息文件路径
server_info_file="ssh.txt"
# 检查服务器信息文件是否存在
if [ ! -f "$server_info_file" ]; then
echo "服务器信息文件未找到: $server_info_file"
exit 1
fi
# 执行命令的函数
execute_command() {
local ip=$1
local port=$2
local user=$3
local password=$4
local command=$5
echo -e "正在连接到 ${green}$ip${none}..."
sshpass -p "$password" ssh -o StrictHostKeyChecking=no -p "$port" "$user@$ip" -Tn "$command" > /tmp/output_ssh.txt 2>&1
exit_status=$?
if [ $exit_status -eq 0 ]; then
echo -e "${green}$ip 上的命令执行成功:${none}"
cat /tmp/output_ssh.txt
else
echo -e "${green}$ip 上的命令执行失败,错误信息:${none}"
cat /tmp/output_ssh.txt
fi
rm /tmp/output_ssh.txt
}
# 循环,直到用户决定停止
while true; do
echo "请输入要在所有服务器上执行的脚本/命令:"
read -r command
# 如果用户没有输入命令,则询问是否退出
if [ -z "$command" ]; then
echo "未输入任何命令。你想要退出吗?(y/n)"
read -r answer
if [ "$answer" = "y" ]; then
break
fi
fi
# 读取服务器信息并执行命令
while IFS=' ' read -r ip port user password; do
execute_command "$ip" "$port" "$user" "$password" "$command"
done < "$server_info_file"
# 询问用户是否继续输入另一个命令
echo "你想要执行另一个脚本/命令吗?(y/n)"
read -r answer
if [ "$answer" != "y" ]; then
break
fi
done
echo "脚本执行完毕。"