如何实现SHELL:用SSH批量登陆到其他服务器,每台服务器登陆密码不同
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了如何实现SHELL:用SSH批量登陆到其他服务器,每台服务器登陆密码不同相关的知识,希望对你有一定的参考价值。
如题
参考技术A 需要采用ssh远程无密码登录:原理是:
客户机
上,先生成
私钥
和公钥,然后把公钥传递到每台要登录的服务器的指定用户目录里即可。
客户机命令:
ssh-keygen
-t
rsa
(回车两次)
ssh-copy-id
-i
~/.ssh/id_rsa.pub
用户名@服务器1
ssh-copy-id
-i
~/.ssh/id_rsa.pub
用户名@服务器2
...
认证成功后,
运行命令
:
ssh
服务器名
“命令名”
不再需要密码
shell脚本实现ssh-copy-id批量自动发送公钥到远程主机
需求
批量实现自动发送公钥到远程主机
环境
firewalld:关闭
selinux:关闭
实现方式
- sshpass命令
- shell调用expect命令
sshpass命令
#!/bin/bash
#
#********************************************************************
#Author: hechunping
#QQ: ×××
#Date: 2019-11-07
#FileName: ssh-sshpass.sh
#URL: hexiaoshuai.blog.51cto.com
#Description: The test script
#Copyright (C): 2019 All rights reserved
#********************************************************************
NET=172.20.200
USER=(root hechunping)
PASSWORD=123456
ssh-keygen -t rsa -P ‘‘ -f ~/.ssh/id_rsa &> /dev/null
sed -i ‘/StrictHostKeyChecking/c StrictHostKeyChecking no‘ /etc/ssh/ssh_config
rpm -q sshpass &> /dev/null || yum -y install sshpass &> /dev/null
for i in {1..254} ; do
{
sshpass -p $PASSWORD ssh-copy-id -i ${USER[0]}@${NET}.${i} &> /dev/null
}&
done
wait
shell调用expect命令
#!/bin/bash
#
#********************************************************************
#Author: hechunping
#QQ: ×××
#Date: 2019-11-07
#FileName: ssh-expect.sh
#URL: hexiaoshuai.blog.51cto.com
#Description: The test script
#Copyright (C): 2019 All rights reserved
#********************************************************************
NET=172.20.200
USER=(root hechunping)
PASSWORD=123456
ssh-keygen -t rsa -P ‘‘ -f ~/.ssh/id_rsa &> /dev/null
for i in {1..254} ; do
{
expect <<EOF
spawn ssh-copy-id -i ${USER[0]}@${NET}.${i}
expect {
"yes/no" { send "yes
";exp_continue }
"password" { send "${PASSWORD}
" }
}
expect eof
EOF
}&
done
wait
以上是关于如何实现SHELL:用SSH批量登陆到其他服务器,每台服务器登陆密码不同的主要内容,如果未能解决你的问题,请参考以下文章
Linux 批量建立信任关系,实现ssh无password登陆的脚本