shell一键免密互信

#!/bin/bash
installpath=$(cd `dirname $0`; pwd)
echo "安装路径: ${installpath}"
#myip=`ip addr | grep 'state UP' -A2 | tail -n1 | awk '{print $2}' | cut -f1 -d '/'`
#echo "当前主机IP: ${myip}"
filepath=${installpath}/files
echo "由于当前环境还未做免密 所以需要安装远程带密码的工具 sshpass"
rpm -ivh ${filepath}/sshpass*.rpm
echo "首先在三台机器先生成 ssh密钥"
ssh-keygen -t dsa -P '' -f ~/.ssh/id_dsa >/dev/null 2>&1
for i in {1..2}
do
    sshpass -p $4 ssh -o 'StrictHostKeyChecking=no' -Tq root@cdh-worker$i <<remotessh
        ssh-keygen -t dsa -P '' -f ~/.ssh/id_dsa >/dev/null 2>&1
        mkdir -p ${filepath}
    exit
remotessh
done
for i in {1..2}
do
        echo "copy master节点公钥到cdh-worker$i节点"
        echo "sshpass -p $4 ssh-copy-id -i ~/.ssh/id_dsa.pub root@cdh-worker$i"
        sshpass -p $4 ssh-copy-id -o 'StrictHostKeyChecking=no' -i ~/.ssh/id_dsa.pub root@cdh-master
        sshpass -p $4 ssh-copy-id -o 'StrictHostKeyChecking=no' -i ~/.ssh/id_dsa.pub root@cdh-worker$i
        echo "发送sshpass安装包到cdh-worker$i节点"
        scp ${filepath}/sshpass*.rpm root@cdh-worker$i:${filepath}
        echo "copy worker$i节点公钥到主节点和其他从节点"
        sshpass -p $4 ssh -o 'StrictHostKeyChecking=no' -Tq root@cdh-worker$i <<remotessh
            rpm -ivh ${filepath}/sshpass*.rpm
            echo "sshpass -p $4 ssh-copy-id -i ~/.ssh/id_dsa.pub root@cdh-master"
            sshpass -p $4 ssh-copy-id -o 'StrictHostKeyChecking=no' -i ~/.ssh/id_dsa.pub root@cdh-master
            sshpass -p $4 ssh-copy-id -o 'StrictHostKeyChecking=no' -i ~/.ssh/id_dsa.pub root@cdh-worker1
            sshpass -p $4 ssh-copy-id -o 'StrictHostKeyChecking=no' -i ~/.ssh/id_dsa.pub root@cdh-worker2
        exit
remotessh
done
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值