在linux系统中,要实现两台主机的无密码连接,需要操作:
比如host2要无密码连接host1:
host1:172.25.254.167
host2:172.25.254.67
host1中操作:
1—>生成公钥私钥对:ssh-keygen
2—>先切换到密钥的存储位置:cd /root/.ssh/(一般默认存储在这里)
3—>将本地主机的公钥复制到本机的authorized_keys文件上:ssh-copy-id -i id_rsa.pub root@172.25.254.167
4—>发送私钥给host2: scp id_rsa kiosk@172.25.254.67:/home/kiosk/.ssh/
在这个时候host2主机就可以无密码连接host1主机
用paramiko进行连接
import paramiko
# 创建一个ssh对象;
client = paramiko.SSHClient()
# 实例化一个私钥对象
private_key = paramiko.RSAKey.from_private_key_file('/home/kiosk/.ssh/id_rsa')
# 2. 解决问题:如果之前没有;连接过的ip, 会出现
# Are you sure you want to continue connecting (yes/no)? yes
# 自动选择yes
client.set_missing_host_key_policy(paramiko.AutoAddPolicy())
# 3. 连接服务器
client.connect(
hostname='172.25.254.167',
username='root',
pkey= private_key ,
)
# 4. 执行操作
stdin, stdout, stderr = client.exec_command('hostname')
# 5. 获取命令的执行结果;
print(stdout.read().decode('utf-8'))
# 6. 关闭连接
client.close()