Python自动化开发学习9-paramiko模块

简介:

第三方库的安装

下面要讲的paramiko是一个第三方库。这是第一次使用到第三方库,要使用第三方库需要先进行安装。不过现在安装过程比较简单,一条命令便可以完成库的下载和安装。下面就用paramiko模块举例安装的方法。

使用系统命令行安装

安装第三方库,建议直接用pip安装。Windows和Linux都适用
pip命令不在环境变量中,所以无法直接运行。可以将pip加到环境变量中,或者cd到 Python\Scripts 目录下,之后使用命令
$ pip install paramiko 等待安装完毕即可使用。

通过pacharm安装

如果使用pacharm,也可以用pacharm来安装。在File->Settings->Project: ->Project Interpreter 里,点右边的+号。
Python自动化开发学习9-paramiko模块
然后在搜索框搜索你要的第三方库,选中后点左下角的“Install Package”进行安装。
Python自动化开发学习9-paramiko模块

paramiko模块

paramiko模块,遵循SSH2协议,支持以加密和认证的方式,进行远程服务器的连接。

SSHClient

可以实现连接远程服务器并执行基本命令

import paramiko
# 创建SSH对象
ssh = paramiko.SSHClient()
# 允许连接不在know_hosts文件中的主机
ssh.set_missing_host_key_policy(paramiko.MissingHostKeyPolicy())
# 连接服务器,下面改一下登录信息
ssh.connect(hostname='192.168.100.11', port=22, username='test', password='123456')
# 执行命令,写死命令或者用下面的获取用户输入
stdin, stdout, stderr = ssh.exec_command('df')
# cmd = input(">>")
# stdin, stdout, stderr = ssh.exec_command(cmd)
# 获取命令结果,标准输出和标准错误应该同时只有一个有值
res, err = stdout.read(), stderr.read()
if res: print('res:\n', res.decode())  # 如果有标准输出,则打印出来
if err: print('err:\n', err.decode())  # 如果有标准错误,则打印出来
# 关闭连接
ssh.close()

上面例子中的第二句 ssh.set_missing_host_key_policy(paramiko.MissingHostKeyPolicy()) ,设置允许没有host_key的连接策略。如果找不到know_hosts文件,或者文件中没有这台主机,如果没有这句,就会报错。如果有这句,那么就执行作为参数的那个方法的策略。作为参数的 paramiko.MissingHostKeyPolicy() 还有另外3个方法。

  • MissingHostKeyPolicy: 这个是下面3个参数的父类,直接就一句pass,就是什么也不做。所以可以正常运行
  • AutoAddPolicy: 自动添加到know_hosts中,那么下次就不会找不到了。如果找不到know_host文件的话,就和上面一样了
  • RejectPolicy: 直接拒绝,会抛出一个错误。默认就是这个,所以不写这句会报错。
  • WarningPolicy: 发出警告,会先报个错,但是不中断,程序还会继续执行

know_hosts文件

在linux系统中,用户家目录下会有一个隐藏文件夹“.ssh”。如果你这台机器没有使用过ssh,可能还没有自动创建这个文件夹。可以在家目录使用命令 $ ls -a 查看到。
模块中是使用 filename = os.path.expanduser('~/.ssh/known_hosts') 来查找到文件,然后获取到其中的主机的。也就是查找用户家目录下.ssh文件夹的know_hosts文件。当然也可以用命令指定查找别处的文件,并且可以调用多次,会将所有的内容合并。比如windows系统中可能没有这个文件,或者不在用户家目录中。如果你有安装的第三方ssh应用,可能会在别的地方。
linux系统中,可以用命令 $ ssh-keygen -R 清理掉已经记录的主机。

连接用Transport封装

模块另外还提供一种连接方式,使用Transport封装。先获取主机名和端口号,然后连接(其实这部分底层就是socket)。直接将这个已经封装好的连接,赋值给SSHClinet的实例。

import paramiko
# 创建SSH对象
ssh = paramiko.SSHClient()
# 允许连接不在know_hosts文件中的主机
ssh.set_missing_host_key_policy(paramiko.MissingHostKeyPolicy())
# 连接服务器,下面改一下登录信息
# ssh.connect(hostname='192.168.100.11', port=22, username='test', password='123456')
# 用下面这段代码代替上面的也能连接
transport = paramiko.Transport(('192.168.100.11', 22))
transport.connect(username='test', password='123456')
ssh._transport = transport
# 执行命令,写死命令或者用下面的获取用户输入
stdin, stdout, stderr = ssh.exec_command('df')
# 获取命令结果,标准输出和标准错误应该同时只有一个有值
res, err = stdout.read(), stderr.read()
if res: print('res:\n', res.decode())  # 如果有标准输出,则打印出来
if err: print('err:\n', err.decode())  # 如果有标准错误,则打印出来
# 关闭连接
ssh.close()

sftp传文件

通过paramiko模块还可以使用sftp进行上传和下载

import paramiko
# 根据实际情况修改你的连接信息
transport = paramiko.Transport(('192.168.100.11', 22))
transport.connect(username='test', password='123456')
# 建立sftp连接
sftp = paramiko.SFTPClient.from_transport(transport)
# 上传文件:源文件,目的文件
sftp.put('local.txt', '/tmp/server.txt')
# 下载文件:源文件,目的文件
sftp.get('/tmp/server.txt', 'from_server.txt')
transport.close()

ssh密钥验证

如果要自动登录,那么需要把用户名和密码事先存放在文件中。这样的做法很不安全,如果让别人读取到这个文件,就有了你所有的机器的访问权限。
这种情况下可以使用密钥认证,实现无密码登录。
这部分是RHCSA学过的内容
生成一对公钥-私钥对,私钥自己保存,公钥发送给需要登录的机器上。完成以上步骤,每次登录就不需要密码了。
ssh-keygen 在本地生成公钥-私钥对
ssh-copy-id [user@]host 将你的公钥发送到需要无密钥登录的主机。缺省user的话就是使用你当前这台机器使用的user
windowns中也可以使用,只需要使用工具先生成一对公钥和私钥。比如CRT
上面的是准备工作。完成后,在paramiko模块里也是以后,使用pkey来代替passwod进行登录。

import paramiko
# 使用命令从文件获取密钥,注意修改文件路径
private_key = paramiko.RSAKey.from_private_key_file('id_rsa')
ssh = paramiko.SSHClient()
ssh.set_missing_host_key_policy(paramiko.MissingHostKeyPolicy())
# 连接服务器,这里要改一下,注意参数
ssh.connect(hostname='192.168.100.11', port=22, username='test', pkey=private_key)
# 执行命令测试一下
stdin, stdout, stderr = ssh.exec_command('df')
res, err = stdout.read(), stderr.read()
if res: print('res:\n', res.decode())  # 如果有标准输出,则打印出来
if err: print('err:\n', err.decode())  # 如果有标准错误,则打印出来
ssh.close()

如果是使用Transport封装,也是一样,把password参数换成pkey。看下面sftp的例子就可以了

sftp也可以使用密钥验证

到这里,应该就没太多问题了

import paramiko
private_key = paramiko.RSAKey.from_private_key_file('id_rsa')
transport = paramiko.Transport(('192.168.100.11', 22))
transport.connect(username='test', password='123456')
sftp = paramiko.SFTPClient.from_transport(transport)
# 上传文件:原文件,目的文件
sftp.put('local.txt', '/tmp/server.txt')
# 下载文件:原文件,目的文件
sftp.get('/root/.ssh/id_rsa', 'id_rsa')
transport.close()








本文转自骑士救兵51CTO博客,原文链接:http://blog.51cto.com/steed/2053138,如需转载请自行联系原作者
相关文章
|
2天前
|
运维 Shell Python
Shell和Python学习教程总结
Shell和Python学习教程总结
|
2天前
|
Python
Python从入门到精通:深入学习面向对象编程——2.1.2继承、封装和多态的概念
Python从入门到精通:深入学习面向对象编程——2.1.2继承、封装和多态的概念
|
2天前
|
开发框架 前端开发 数据库
Python从入门到精通:3.3.2 深入学习Python库和框架:Web开发框架的探索与实践
Python从入门到精通:3.3.2 深入学习Python库和框架:Web开发框架的探索与实践
|
2天前
|
数据采集 数据可视化 数据处理
Python从入门到精通的文章3.3.1 深入学习Python库和框架:数据处理与可视化的利器
Python从入门到精通的文章3.3.1 深入学习Python库和框架:数据处理与可视化的利器
|
2天前
|
存储 网络协议 关系型数据库
Python从入门到精通:2.3.2数据库操作与网络编程——学习socket编程,实现简单的TCP/UDP通信
Python从入门到精通:2.3.2数据库操作与网络编程——学习socket编程,实现简单的TCP/UDP通信
|
3天前
|
人工智能 Python
【Python实用技能】建议收藏:自动化实现网页内容转PDF并保存的方法探索(含代码,亲测可用)
【Python实用技能】建议收藏:自动化实现网页内容转PDF并保存的方法探索(含代码,亲测可用)
21 0
|
9天前
|
机器学习/深度学习 算法 Python
使用Python实现集成学习算法:Bagging与Boosting
使用Python实现集成学习算法:Bagging与Boosting
19 0
|
10天前
|
Python
python学习-函数模块,数据结构,字符串和列表(下)
python学习-函数模块,数据结构,字符串和列表
53 0
|
缓存 Python 数据安全/隐私保护

热门文章

最新文章