前言
当我们需要对多台虚拟机进行jdk环境的配置,我们需要使用这种自动化脚本。
一些准备
在开始执行自动化脚本之前,我们需要保证各台虚拟机(mini1、mini2、mini3、mini4)可以联网,并且能够访问外网或者我们搭建好的内部镜像。并且在mini4上面已经安装好httpd,关于httpd的使用这里不再赘述。因为此次在连接各个服务器的时候是使用的hostname,所以在hosts文件中应该已经注明了各自的ip才行。
主要步骤
1.复制bash文件到服务器mini1
,两份bash文件如下:
- boot.sh
#!/bin/bash
SERVERS="mini1 mini2 mini3 mini4"
PASSWORD=hadoop&^%$balabala
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
}
yum install -y expect
ssh_copy_id_to_all
for SERVER in $SERVERS
do
scp install.sh root@$SERVER:/root
ssh root@$SERVER chmod +x /root/install.sh
ssh root@$SERVER /root/install.sh
done
- install.sh
#!/bin/bash
BASE_SERVER=mini4
yum install -y wget
wget $BASE_SERVER/soft/jdk-7u67-linux-x64.tar.gz
tar -zxvf jdk-7u67-linux-x64.tar.gz -C /usr/local
cat >> /etc/profile << EOF
export JAVA_HOME=/usr/local/jdk1.7.0_67
export PATH=\$PATH:\$JAVA_HOME/bin
EOF
2.执行脚本boot.sh,如果提示权限不足,可以增加它的执行权限:
chmod +x boot.sh
chmod +x install.sh
注意事项及总结
当发生异常的时候,我们需要仔细分析错误信息。在访问httpd所提供的静态资源出现未找到的问题时要认真排查。说千遍道万遍,不如动手做一遍。发生错误很正常,及时总结分析就好。