当咱们须要对多台虚拟机进行jdk环境的配置,咱们须要使用这种自动化脚本。linux
在开始执行自动化脚本以前,咱们须要保证各台虚拟机(mini一、mini二、mini三、mini4)能够联网,而且可以访问外网或者咱们搭建好的内部镜像。而且在mini4上面已经安装好httpd,关于httpd的使用这里再也不赘述。由于这次在链接各个服务器的时候是使用的hostname,因此在hosts文件中应该已经注明了各自的ip才行。bash
mini1
,两份bash文件以下:#!/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
#!/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
chmod +x boot.sh chmod +x install.sh
当发生异常的时候,咱们须要仔细分析错误信息。在访问httpd所提供的静态资源出现未找到的问题时要认真排查。说千遍道万遍,不如动手作一遍。发生错误很正常,及时总结分析就好。服务器