當咱們須要對多臺虛擬機進行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所提供的靜態資源出現未找到的問題時要認真排查。說千遍道萬遍,不如動手作一遍。發生錯誤很正常,及時總結分析就好。服務器