您好,登錄后才能下訂單哦!
這篇文章給大家分享的是shell實現批量免密鑰登錄的方法,相信大部分人都還沒學會這個技能,為了讓大家學會,給大家總結了以下內容,話不多說,一起往下看吧。
注意:ip.txt和send_ssh_key.sh必須在同一根目錄下
# 根據以下格式寫入服務器信息ip.txt,用于免密鑰登錄
#-----------
# ip:password
#192.168.1.110:7758521
#192.168.1.111:7758521
#192.168.1.112:7758521
#-----------
#!/bin/bash
# 生成ssh key
if [[ ! -f "/root/.ssh/id_rsa" ]];then
echo "gen ssh key"
ssh-keygen -t rsa -b 2048 -N '' -f /root/.ssh/id_rsa
fi
# 檢測是否安裝了 expect
if ! expect -v &>/dev/null;then
echo "install expect"
yum install expect -y
fi
# 循環文件中的ip
for p in $(cat ip.txt|grep -v '#');do
ip=$(echo "$p"|cut -f1 -d":") # 取出當前IP
password=$(echo "$p"|cut -f2 -d":") # 取出當前密碼
# expect 交互過程
expect -c "
spawn ssh-copy-id -i /root/.ssh/id_rsa.pub root@$ip
expect {
\"*yes/no*\" {send \"yes\r\"; exp_continue}
\"*password*\" {send \"$password\r\"; exp_continue}
\"*Password*\" {send \"$password\r\";}
}
"
看完這篇文章,你們學會shell實現批量免密鑰登錄的方法了嗎?如果還想學到更多技能或想了解更多相關內容,歡迎關注億速云行業資訊頻道,感謝各位的閱讀。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。