Linux多台主机批量命令脚本

如果你只维护着1台机器,这篇文章对你可能就没啥用处了。
如果你维护着大量的Linux主机,就需要这样一个脚本帮助你完成日常维护工作,脚本很简单,主要是提供一个思路,其他功能的脚步都可以按照此脚本的流程实现。
1、首先你需要指定一台主机作为信任主机,这样从这台主机登录其他机器就不需要密码了。
如何设置信任主机?
假设有四台机器: 192.168.2.1~192.168.2.4,其中192.168.2.1为信任机,那么在192.168.2.1上运行如下命令:

ssh-keygen -t rsa    //此处一路回车,生成秘钥

scp .ssh/id_rsa.pub 192.168.2.2:~/   //把秘钥拷贝到其他远程机器

ssh 192.168.2.2 'cat id_rsa.pub >> .ssh/authorized_keys'  //(远程执行命令)在远程机器上生成认证文件

经过这几步,从192.168.2.1 ssh登陆192.168.2.2时,就不会再需要输入密码了。同样的步骤再执行3、4的极其。


2、在信任机器上创建hostlist文本,(和脚本放在同一目录)
文本文件hostlist可以如下
192.168.2.2
192.168.2.3
192.168.2.4


3、创建doCommand.sh脚本:

#!/bin/sh
	 
doCommand()
{
	hosts=`sed -n '/^[^#]/p' hostlist`
	for host in $hosts
	    do
	        echo ""
	        echo HOST $host
	        ssh $host "$@"
	    done
	return 0
}
	 
	if [ $# -lt 1 ]
	then
	        echo "$0 cmd"
	        exit
	fi
	doCommand "$@"
	echo "return from doCommand"
执行命令(记得先对doCommand.sh增加执行权限 chmod u+x doCommand.sh)
./doCommand.sh “ls -al /root/”
这样该脚本就会在每台机器上执行”ls -al /root/”这个命令,并返回结果在信任主机上。

你可能感兴趣的:(linux)