为了账号安全,请及时绑定邮箱和手机立即绑定

python paramiko模块

标签:
Python

paramiko模块能实现Linux的ssh功能


1、实现一个简单的ssh,登录到其它服务器执行一条命令


import paramiko    #导入模块,前提是用pip安装过

ssh = paramiko.SSHClient()

ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())   #允许将信任的主机自动加入到host_allow 列表,此方法必须放在connect方法的前面

ssh.connect(hostname='192.168.200.102', port=22, username='root', password='666666')#连接服务器

stdin, stdout, stderr = ssh.exec_command('hostname')#stdin标准输入,stdout标准输出,stderr标准错误

res,err = stdout.read(),stderr.read()  

result = res if res else err     #三元远算

print(result.decode().strip())

ssh.close()


2、以上的示例是实现在服务器执行命令,接下来的示例是传递文件,也就是实现scp功能

import paramiko

transport = paramiko.Transport(("192.168.200.102",22))

transport.connect(username="root",password="666666")

sftp = paramiko.SFTPClient.from_transport(transport)

sftp.put("/etc/passwd","/tmp/passwd.bak")

sftp.get("/tmp/passwd.bak","/tmp/passwd.bak")

transport.close()


3、基于秘钥的连接,前提是生成密钥对

import paramiko

#指定本地的私钥

private_key = paramiko.RSAKey.from_private_key_file("/root/.ssh/id_rsa")

ssh = paramiko.SSHClient()

ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())

ssh.connect(hostname="192.168.200.102",port=22,username="root",pkey=private_key)

stdin,stdout,stderr = ssh.exec_command("free -m")

print(stdout.read().decode())

ssh.close()


4、基于秘钥的传输文件

import paramiko

private_key = paramiko.RSAKey.from_private_key_file("/root/.ssh/id_rsa")

transport = paramiko.Transport(("192.168.200.102",22))

transport.connect(username="root",pkey=private_key)

sftp = paramiko.SFTPClient.from_transport(transport)

sftp.put("/etc/passwd","/tmp/passwd.baak")

sftp.get("/tmp/passwd.baak","/tmp/passwd.baak")

transport.close()


点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号

举报

0/150
提交
取消