使用sshpass在Linux服务器上批量执行脚本
用途描述:如果Linux服务器未配置免密登录,每次使用ssh执行远程脚本时,都需要输入密码。使用sshpass命令可以在多个Linux服务器上批量执行脚本,操作步骤如下:1、安装sshpass$ yum install -y sshpass2、服务器检查脚本脚本文件: check_cmd.sh#!/bin/shecho ---------------------------------------
·
用途描述:
如果Linux服务器未配置免密登录,每次使用ssh执行远程脚本时,都需要输入密码。
使用sshpass命令可以在多个Linux服务器上批量执行脚本,操作步骤如下:
1、安装sshpass
$ yum install -y sshpass
2、服务器检查脚本
编写服务器检查脚本,检查内容可根据实际情况进行自定义;
以下提供ip,服务,端口,进程,目录等内容的检查。
脚本文件: check_cmd.sh
#!/bin/sh
echo ----------------------------------------
echo 检查ip:
ip a|grep 192
echo 检查服务:nginx
systemctl list-units|grep nginx
echo 检查端口:8080
netstat -nao |grep 8080|awk '{print $6}'| sort |uniq -c |sort -nr
echo 检查进程:java
ps -ef|grep java
echo 检查目录:home
ll /home
echo ----------------------------------------
3、批量密码登录(sshpass)
设置需要对哪些Linux服务器执行检查脚本;
以下列出如何检查3台服务器,可根据实际需求进行扩展。
注意:
首次执行脚本前,需要使用ssh预先登录一下每个服务器。
脚本文件: check_ips.sh
#!/bin/sh
LOG_FILE=result.`date +%Y%m%dT%H%M%S`.log
sshpass -p '123456' ssh root@192.168.0.11 < check_cmd.sh >>$LOG_FILE
sshpass -p '123456' ssh root@192.168.0.12 < check_cmd.sh >>$LOG_FILE
sshpass -p '123456' ssh root@192.168.0.13 < check_cmd.sh >>$LOG_FILE
4、执行脚本
# 添加可执行权限
chmod +x check_cmd.sh
chmod +x check_ips.sh
# 执行脚本
./check_ips.sh
执行脚本后,将在当前目录生成一个执行日志文件:result.***.log
更多推荐
已为社区贡献2条内容
所有评论(0)