服务器有5台,名字分别为lijie1,lijie2,lijie3,lijie4,lijie5
在其中一台服务器上面部署两个脚本,脚本内容如下:
- 1.start.sh
#!/bin/bash
SERVERS="lijie1 lijie2 lijie3 lijie4 lijie5"
PASSWORD=111111
auto_ssh_copy_id() {
expect -c "set timeout -1;
spawn ssh-copy-id $1;
expect {
*(yes/no)* {send -- yes\r;exp_continue;}
*assword:* {send -- $2\r;exp_continue;}
eof {exit 0;}
}";
}
ssh_copy_id_to_all() {
for SERVER in $SERVERS
do
auto_ssh_copy_id $SERVER $PASSWORD
done
}
ssh_copy_id_to_all
for SERVER in $SERVERS
do
scp install.sh root@$SERVER:/root
ssh root@$SERVER /root/install.sh
done
1.先执行ssh_copy_id_to_all函数
2.执行for循环,对每个地址执行auto_ssh_copy_id函数
3.用人机交互式expect让机器自动执行完ssh-copy-id
4.把当前目录下的install.sh分发到各个节点的/root目录下
5.用ssh连接各个目录并分别执行install.sh
其中expect 表示人机交互根据提示自动答复完成设置,set timeout -1表示无限等待时间,spawn 后面跟执行的命令,expect{}块里面表示匹配提示符,然后输入,\r模拟输入完成回车确认,eof表示结束。
- 2.install.sh
#!/bin/bash
yum install -y wget
wget http://download.oracle.com/otn-pub/java/jdk/7u79-b15/
jdk-7u79-linux-x64.tar.gz
tar -zxvf jdk-7u45-linux-x64.tar.gz -C /usr/local
cat >> /etc/profile << EOF
export JAVA_HOME=/usr/local/jdk1.7.0_45
export PATH=\$PATH:\$JAVA_HOME/bin
EOF
1.安装wget工具
2.通过wget下载jdk7的文件
3.解压,并修改环境变量
其中
cat >> /etc/profile << EOF
xxxx
xxxx
EOF
表示cat一个临时文件到/etc/profile文件中,EOF表示文件开始和结束然后<<重定向到里面。
wget后面的jdk的源最好配置在一个局域网的apache服务器中,不然每次都要从官网下载,导致浪费时间。
- 3.执行start.sh
./start.sh