#!/bin/bash #ssh免密登錄shell腳本 #配置免密登錄的所有機子都要運行該腳本 #修改/etc/ssh/sshd_config配置文件 #sed -i 's/被替換的內容/替換成的內容/' /配置文件地址 #sed -i 's/#PubkeyAuthentication yes/PubkeyAuthentication yes/' /etc/ssh/sshd_config #cat >> /etc/ssh/sshd_config <<EOF #RSAAuthentication yes #EOF #yum install expect expect-devel tcl -y #安裝expect echo "按enter鍵3次即可" ssh-keygen -t rsa #生成祕鑰(按enter鍵3次即可生成) SERVERS="arango mysql es redis" #需要配置的主機名 PASSWORD=123456 #需要配置的主機登錄密碼 #將本機生成的公鑰複製到其他機子上 #如果(yes/no)則自動選擇yes繼續下一步 #如果password:怎自動將PASSWORD寫在後面繼續下一步 auto_ssh_copy_id(){ expect -c "set timeout -1; spawn ssh-copy-id $1; expect { *(yes/no)* {send -- yes\r;exp_continue;} *password:* {send -- $2\r;exp_continue;} eof {exit 0;} }"; } ssh_copy_id_to_all(){ for SERVER in $SERVERS #遍歷要發送到各個主機的ip do auto_ssh_copy_id $SERVER $PASSWORD done } ssh_copy_id_to_all
服務器免密登陸shell腳本
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.