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

前言

当咱们须要对多台虚拟机进行jdk环境的配置,咱们须要使用这种自动化脚本。linux

一些准备

在开始执行自动化脚本以前,咱们须要保证各台虚拟机(mini一、mini二、mini三、mini4)能够联网,而且可以访问外网或者咱们搭建好的内部镜像。而且在mini4上面已经安装好httpd,关于httpd的使用这里再也不赘述。由于这次在链接各个服务器的时候是使用的hostname,因此在hosts文件中应该已经注明了各自的ip才行。bash

主要步骤

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所提供的静态资源出现未找到的问题时要认真排查。说千遍道万遍,不如动手作一遍。发生错误很正常,及时总结分析就好。服务器

相关文章
相关标签/搜索