使用paramiko基于公钥和私钥连接

目标:
1). 172.25.254.3 - host3
172.25.254.4 - host4

2). host4实现无密码连接host3



 host3操作: 生成公钥和私钥, 并发送私钥给host4
          993  ssh-keygen
          994  cd  /root/.ssh/
          995  ls
          996  ssh-copy-id  -i  id_rsa.pub root@172.25.254.3
          997  scp id_rsa kiosk@172.25.254.4:/home/kiosk/.ssh/


host4操作:
a). shell命令检测是否可以成功?
ssh root@172.25.254.3

b). 代码实现:
    import paramiko
    # ssh root@172.25.254.250
    # 创建一个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.3',
        username='root',
        pkey= private_key ,

    )
    # 4. 执行操作
    stdin, stdout, stderr = client.exec_command('hostname')
    # 5. 获取命令的执行结果;
    print(stdout.read().decode('utf-8'))
    # 6. 关闭连接
    client.close()

import paramiko
#ssh root@172.25.254.250
创建一个ssh对象;
client = paramiko.SSHClient()

实例化一个私钥对象
private_key = paramiko.RSAKey.from_private_key_file(‘doc/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.3’,
username=‘root’,
pkey= private_key ,

)
4. 执行操作
stdin, stdout, stderr = client.exec_command(‘hostname’)
5. 获取命令的执行结果;
print(stdout.read().decode(‘utf-8’))
6. 关闭连接
client.close()

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 4
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值