阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

Linux集群自动化搭建(生成密钥对+分发公钥+远程批量执行脚本)

201次阅读
没有评论

共计 2950 个字符,预计需要花费 8 分钟才能阅读完成。

之前介绍过 ansible 的使用,通过 ssh 授权批量控制服务器集群 但是生成密钥和分发公钥的时候都是需要确认密码的,这一步也是可以自动化的,利用 ssh + expect + scp 就可以实现,其实只用这几个命令结合也可以实现类似 ansible 的功能了 为了远程操作服务器进行环境初始化,总结我们都需要以下几步操作 1.ssh-keygen 生成密钥对 2. 将生成的公钥发送到 node 服务器 3.scp 拷贝安装包到 node 服务器 4.ssh 远程执行拷贝过去的安装包

下面进行集群环境初始化脚本的编写,通过 ssh + expect + scp 实现服务器集群自动化搭建

第一步,服务器准备
这里使用 docker 模拟几台服务器,分别命名为 node2,node3,node4(使用镜像 chenqionghe/Ubuntu,密码统一为 88888888),生产环境为 ip 或 host

docker run -d –name node2 -p 2223:22 chenqionghe/ubuntu
docker run -d –name node3 -p 2224:22 chenqionghe/ubuntu
docker run -d –name node4 -p 2225:22 chenqionghe/ubuntu

还得有一台主控制服务器 node1,负责操作所有的服务器节点

docker run -d –name node1 -p 2222:22 \
–link node2:node2 \
–link node3:node3 \
–link node4:node4 \
chenqionghe/ubuntu

初始化完成后进入 node1 节点

ssh root@127.0.0.1 -p 2222

安装必须软件

apt-get install expect -y

创建存放脚本的目录~/env

mkdir -p ~/env && cd ~/env

这里先模拟一个简单的安装包 scripts/install.sh,安装 vim 命令

mkdir scripts
cat > scripts/install.sh <<EOF
#!/bin/bash bash
apt-get install vim -y
EOF

创建机器列表配置文件,vim nodes.txt

node2
node3
node4

第二步 编写自动化脚本
1. 无交互 ssh-keygen 生成密钥对脚本,vim ssh-keygen.exp

#!/usr/bin/expect
#set enter “\n”
spawn ssh-keygen
expect {
        “*(/root/.ssh/id_rsa)” {send “\r”;exp_continue}
        “*(empty for no passphrase)” {send “\r”;exp_continue}
        “*again” {send “\r”}
}
expect eof

2. 无交互分发公钥脚本,vim send-sshkey.exp

#!/usr/bin/expect
if {$argc != 2} {
 send_user “usage: expect send-sshkey.exp file host\n”
 exit
}
#define var
set file [lindex $argv 0]
set host [lindex $argv 1]
set password “88888888”
spawn ssh-copy-id -i $file -p 22 root@$host
expect {
        “yes/no” {send “yes\r”;exp_continue}
        “*password” {send “$password\r”}
}
expect eof

3. 远程批量执行 ssh 脚本, vim mssh.sh

#!/bin/bash
Port=22
if [$# -lt 1];then
    echo “Usage: `basename $0` command”
    exit
fi
echo $@
for v in `cat nodes.txt`
do
    ssh -t -p ${Port} root@${v} $@
    if [$? -eq 0];then
        echo “ 执行成功:$v”
    else
        echo “ 执行失败:$v”
    fi
done

4. 自动化部署脚本,vim auto-deploy.sh

#!/usr/bin/env bash
# 机器列表
HostList=`cat nodes.txt`
# 端口号
Port=22
# 1. 无交互生成密钥对
if [! -f ~/.ssh/id_rsa.pub];then
    expect ssh-keygen.exp
fi
# 2. 无交互分发公密钥
for v in ${HostList}
do
    expect send-sshkey.exp ~/.ssh/id_rsa.pub ${v}
    if [$? -eq 0];then
        echo “ 公钥 - 发送成功:$v”
    else
        echo “ 公钥 - 发送失败:$v”
    fi
done
# 3. 分发脚本文件(安装软件包)
for v in ${HostList}
do
    scp -P ${Port} -rp ~/env/scripts root@${v}:~
    if [$? -eq 0];then
        echo “scripts- 发送成功:$v”
    else
        echo “scripts- 发送失败:$v”
    fi
done
# 4. 使用脚本文件安装
for v in ${HostList}
do
    ssh -t -p ${Port} root@${v} /bin/bash ~/scripts/install.sh
done

到这里所有的文件已经创建完成,整个 env 目录结构如下

├── auto-deploy.sh
├── mssh.sh
├── nodes.txt
├── scripts
│  └── install.sh
├── send-sshkey.exp
└── ssh-keygen.exp

第三步 执行自动化脚本查看效果

sh auto-deploy.sh

执行成功结果

spawn ssh-keygen

公钥 - 发送成功:node2

公钥 - 发送成功:node3

公钥 - 发送成功:node4
install.sh 100% 40 41.4KB/s 00:00
scripts- 发送成功:node2
install.sh 100% 40 45.0KB/s 00:00
scripts- 发送成功:node3
install.sh 100% 40 39.9KB/s 00:00
scripts- 发送成功:node4

Connection to node4 closed.

出现上面的结果代表 3 个 node 节点已经初始化完成,拷贝公钥 + 安装软件成功!

我们再来执行一下远程命令脚本,查看所有服务器系统类型

sh mssh.sh “cat /etc/os-release|head -n 1”

执行结果如下

cat /etc/os-release|head -n 1
NAME=”Ubuntu”
Connection to node2 closed.
执行成功:node2
NAME=”Ubuntu”
Connection to node3 closed.
执行成功:node3
NAME=”Ubuntu”
Connection to node4 closed.
执行成功:node4

这样就实现了自动化创建密钥对 + 分发公钥 + 所有服务器软件环境安装 + 批量远程执行脚本 mssh.sh,麻雀虽小,五脏俱全,绝对是干货!light weight baby!

正文完
星哥说事-微信公众号
post-qrcode
 0
星锅
版权声明:本站原创文章,由 星锅 于2022-01-21发表,共计2950字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中