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,如需转载请自行联系原作者
相关文章
|
3月前
|
安全 JavaScript 开发者
Python 自动化办公神器|一键转换所有文档为 PDF
本文介绍一个自动化批量将 Word、Excel、PPT、TXT、HTML 及图片转换为 PDF 的 Python 脚本。支持多格式识别、错误处理与日志记录,适用于文档归档、报告整理等场景,大幅提升办公效率。仅限 Windows 平台,需安装 Office 及相关依赖。
201 0
|
4月前
|
Web App开发 存储 前端开发
Python+Selenium自动化爬取携程动态加载游记
Python+Selenium自动化爬取携程动态加载游记
|
1月前
|
存储 数据采集 监控
Python定时爬取新闻网站头条:从零到一的自动化实践
在信息爆炸时代,本文教你用Python定时爬取腾讯新闻头条,实现自动化监控。涵盖请求、解析、存储、去重、代理及异常通知,助你构建高效新闻采集系统,适用于金融、电商、媒体等场景。(238字)
309 2
|
2月前
|
数据采集 监控 Shell
无需Python:Shell脚本如何成为你的自动化爬虫引擎?
Shell脚本利用curl/wget发起请求,结合文本处理工具构建轻量级爬虫,支持并行加速、定时任务、增量抓取及分布式部署。通过随机UA、异常重试等优化提升稳定性,适用于日志监控、价格追踪等场景。相比Python,具备启动快、资源占用低的优势,适合嵌入式或老旧服务器环境,复杂任务可结合Python实现混合编程。
|
4月前
|
存储 数据采集 数据可视化
Python自动化分析知网文献:爬取、存储与可视化
Python自动化分析知网文献:爬取、存储与可视化
|
4月前
|
数据采集 存储 监控
Python爬虫自动化:定时监控快手热门话题
Python爬虫自动化:定时监控快手热门话题
|
4月前
|
安全 数据库 数据安全/隐私保护
Python办公自动化实战:手把手教你打造智能邮件发送工具
本文介绍如何使用Python的smtplib和email库构建智能邮件系统,支持图文混排、多附件及多收件人邮件自动发送。通过实战案例与代码详解,帮助读者快速实现办公场景中的邮件自动化需求。
418 0
|
1月前
|
存储 JavaScript Java
(Python基础)新时代语言!一起学习Python吧!(四):dict字典和set类型;切片类型、列表生成式;map和reduce迭代器;filter过滤函数、sorted排序函数;lambda函数
dict字典 Python内置了字典:dict的支持,dict全称dictionary,在其他语言中也称为map,使用键-值(key-value)存储,具有极快的查找速度。 我们可以通过声明JS对象一样的方式声明dict
169 1
|
1月前
|
算法 Java Docker
(Python基础)新时代语言!一起学习Python吧!(三):IF条件判断和match匹配;Python中的循环:for...in、while循环;循环操作关键字;Python函数使用方法
IF 条件判断 使用if语句,对条件进行判断 true则执行代码块缩进语句 false则不执行代码块缩进语句,如果有else 或 elif 则进入相应的规则中执行
257 1
|
9月前
|
C语言 Python
Python学习:内建属性、内建函数的教程
本文介绍了Python中的内建属性和内建函数。内建属性包括`__init__`、`__new__`、`__class__`等,通过`dir()`函数可以查看类的所有内建属性。内建函数如`range`、`map`、`filter`、`reduce`和`sorted`等,分别用于生成序列、映射操作、过滤操作、累积计算和排序。其中,`reduce`在Python 3中需从`functools`模块导入。示例代码展示了这些特性和函数的具体用法及注意事项。
188 2