使用自动化脚本部署多台虚拟机

前言

当我们需要对多台虚拟机进行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所提供的静态资源出现未找到的问题时要认真排查。说千遍道万遍,不如动手做一遍。发生错误很正常,及时总结分析就好。

    原文作者:hengbao
    原文地址: https://segmentfault.com/a/1190000013208873
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞