trrtrtrt 发表于 2018-4-10 15:10:29

python paramiko模块

                                                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()


                                       

页: [1]
查看完整版本: python paramiko模块