python实战之paramiko模块

上一篇:Python实战之socket初版 Linux粘包问题 点击跳转
目录篇:python相关目录篇 点击跳转
下一篇:Python实战之processing进程(多进程,进程池,lock锁,进程间的通讯(QUEUES,PIPE,MANAGER) 点击跳转

目录

  • paramiko介绍
  • 基于密码实战ssh连接和上传下载文件操作
  • 基于秘钥实战连接和上传下载操作

paramiko介绍

paramiko是用python语言写的一个模块,遵循SSH2协议,支持以加密和认证的方式,进行远程服务器的连接。

由于使用的是python这样的能够跨平台运行的语言,所以所有python支持的平台,如Linux, Solaris, BSD, MacOS X, Windows等,paramiko都可以支持,因此,如果需要使用SSH从一个平台连接到另外一个平台,进行一系列的操作时,paramiko是最佳工具之一。

举个常见的例子,现有这样的需求:需要使用windows客户端,远程连接到Linux服务器,查看上面的日志状态,大家通常使用的方法会是:

1:用telnet

2:用PUTTY

3:用WinSCP

4:用XManager等…

那现在如果需求又增加一条,要从服务器上下载文件,该怎么办?那常用的办法可能会是:

1:Linux上安装FTP并配置

2:Linux上安装Sambe并配置…

大家会发现,常见的解决方法都会需要对远程服务器必要的配置,如果远程服务器只有一两台还好说,如果有N台,还需要逐台进行配置,或者需要使用代码进行以上操作时,上面的办法就不太方便了。

使用paramiko可以很好的解决以上问题,比起前面的方法,它仅需要在本地上安装相应的软件(python以及PyCrypto),对远程服务器没有配置要求,对于连接多台服务器,进行复杂的连接操作特别有帮助。

基于密码实战ssh连接和上传下载文件操作

ssh.py #相当于 ssh简单连接操作原理

__author__ = "Burgess Zheng"

import paramiko
# 创建SSH对象
ssh = paramiko.SSHClient()
# 允许连接不在know_hosts文件中的主机#如:ssh rsa加密连接原理
ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())
# 连接服务器
ssh.connect(hostname='10.0.0.150', port=52113, username='root', password='123456')
# 执行命令
stdin, stdout, stderr = ssh.exec_command('df')#Linux命令返回3个值
# 执行ssh.exec_command('df') 该命令会返回3个值
#stdin:标准输入  stdout:标准输出    stderr:标准错误
res,err = stdout.read(),stderr.read()
#stdoutread():读标准输出的结果  stderr.read()读标准错误的结果
#把读出的结果分别赋值给res和err
result = res if res else err
#三元运算 如果res有值result = res 如果res没值就 result = err
print(result.decode())

# 关闭连接
ssh.close()

ssh_sft.py  #相当于 ssh的scp传文件原理

__author__ = "Burgess Zheng"

import paramiko
transport = paramiko.Transport(('10.0.0.31', 52113))
transport.connect(username='root', password='123456')
#上面的只做连接

sftp = paramiko.SFTPClient.from_transport(transport)

#sftp.put('笔记', '/tmp/test_from_win')
    #将location.py 上传至服务器 /tmp/test.py


sftp.get('/root/oldgirl.txt', 'fromlinux.txt')
# 将remove_path 下载到本地 local_path

transport.close()

 

基于秘钥实战连接和上传下载操作

ssh rsaa  #python基于密钥的连接(和ssh基于密钥连接一样的)

__author__ = "Burgess Zheng"

#基于秘钥连接

import paramiko

private_key = paramiko.RSAKey.from_private_key_file('id_rsa31.txt')
#指定你的私钥的位置

# 创建SSH对象
ssh = paramiko.SSHClient()

# 允许连接不在know_hosts文件中的主机
ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())

# 连接服务器
ssh.connect(hostname='10.0.0.41', port=52113, username='gongli', pkey=private_key)

# 执行命令
stdin, stdout, stderr = ssh.exec_command('df')
result = stdout.read()
print(result.decode())
stdin, stdout2, stderr = ssh.exec_command('ifconfig')#两条命令可以当做一条命令使用(''df;ifconfg)
# 获取命令结果
result2 = stdout2.read()
print(result2.decode())

# 关闭连接
ssh.close()

ssh sftp #python基于密钥的上传下载(和ssh scp基于公钥上传下载一样的)

import paramiko
 
private_key = paramiko.RSAKey.from_private_key_file('/home/auto/.ssh/id_rsa')
 
transport = paramiko.Transport(('hostname', 22))
transport.connect(username='wupeiqi', pkey=private_key )
 
sftp = paramiko.SFTPClient.from_transport(transport)
# 将location.py 上传至服务器 /tmp/test.py
sftp.put('/tmp/location.py', '/tmp/test.py')
# 将remove_path 下载到本地 local_path
sftp.get('remove_path', 'local_path')
 
transport.close()

上一篇:Python实战之socket初版 Linux粘包问题 点击跳转
目录篇:python相关目录篇 点击跳转
下一篇:Python实战之processing进程(多进程,进程池,lock锁,进程间的通讯(QUEUES,PIPE,MANAGER) 点击跳转​​​​​​​

你可能感兴趣的:(Python篇)