python中使用paramiko模块并实现远程连接服务器执行上传下载功能


Posted in Python onFebruary 29, 2020

paramiko模块

paramiko是一个用于做远程控制的模块,使用该模块可以对远程服务器进行命令或文件操作,paramiko是用python语言写的一个模块,遵循SSH2协议,支持以加密和认证的方式,进行远程服务器的连接。

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

因此,如果需要使用SSH从一个平台连接到另外一个平台,进行一系列的操作时,paramiko是最佳工具之一。

通过ssh链接服务器并执行想要的命令,类似于XShell

ansible(远程批量管理服务器)底层源码其实就是paramiko模块实现的

安装

pip3 install paramiko

使用

前提须知:paramiko模块即支持用户名密码的方式,也支持公钥私钥的方式操作服务器

1.用户名密码的方式:

# 执行命令
import paramiko
# 创建链接对象
ssh = paramiko.SSHClient()
# 允许链接不在know_hosts文件中的主机
ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())
# 链接服务器
ssh.connect(hostname='服务器ip地址',port='端口号',username='用户名',password='密码')
# 执行命令
stdin, stdout, stderr = ssh.exec_command('ip a')
"""
stdin 是用来输入额外的参数的  -y
stdout 命令的返回结果
stderr 错误的结果
"""
# 获取命令执行的结果
res = stdout.read()
print(res.decode('utf-8'))
# 关闭链接
ssh.close()

2.公钥私钥的方式

首先在windows上产生公钥私钥对

可以用openssl工具产生,也可以用Git Bash工具产生(需要安装git)
1.打开 Git Bash工具 输入命令 ssh-keygen
2.输入完命令一直按回车即可
3.在  c/user/用户名下的文件/.ssh 的目录中生成了两个密钥文件。id_rsa 为私钥,id_rsa.pub 为公钥
4.将公钥内容复制到你的linux服务器下的 /root/.ssh/authorized_keys文件中即可

复制私钥文件到项目根目录下,我这里重命名为a.txt

import paramiko
# 读取本地私钥
private_key = paramiko.RSAKey.from_private_key_file('a.txt')
# 创建SSH对象
ssh = paramiko.SSHClient()
# 允许连接不在know_hosts文件中的主机
ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())
# 连接服务器
ssh.connect(hostname='服务器ip地址', port=22, username='用户名', pkey=private_key)
# 执行命令
stdin, stdout, stderr = ssh.exec_command('ls /')
# 获取命令结果
result = stdout.read()
print(result.decode('utf-8'))
# 关闭连接
ssh.close()

实现上传下载文件

1.用户名和密码的方式:

import paramiko
# 用户名和密码
transport = paramiko.Transport(('服务器ip地址', 22))
transport.connect(username='用户名', password='密码')
sftp = paramiko.SFTPClient.from_transport(transport)
# 上传文件
# sftp.put("a.txt", '/data/tmp.txt') # 注意上传文件到远程某个文件下 文件必须存在
# 下载文件
sftp.get('/data/tmp.txt', 'hahaha.txt') # 将远程文件下载到本地并重新命令
transport.close()

2.公钥和私钥的方式:

import paramiko
private_key = paramiko.RSAKey.from_private_key_file('a.txt')
transport = paramiko.Transport(('服务器地址', 22))
transport.connect(username='用户名', pkey=private_key)
sftp = paramiko.SFTPClient.from_transport(transport)
# 将location.py 上传至服务器 /tmp/test.py
sftp.put('manage.py', '/data/test.py')
# 将remove_path 下载到本地 local_path
sftp.get('remove_path', 'local_path')
transport.close()

下面将执行命令和上传下载文件 封装到一个类里面

SSHProxy类的封装

假如我想链接服务器执行三条命令,并且上传一个文件内容

大部分都会操作几次就链接几次服务器,效率较低,代码冗余

我们想实现一个类里面包含了执行命令和上传下载文件的操作

# 类的代码无需掌握 只需要会拷贝使用即可
import paramiko
class SSHProxy(object):
  # 这里的参数 你可以再加公钥私钥的形式
  def __init__(self, hostname, port, username, password):
    self.hostname = hostname
    self.port = port
    self.username = username
    self.password = password
    self.transport = None
  def open(self): # 给对象赋值一个上传下载文件对象连接
    self.transport = paramiko.Transport((self.hostname, self.port))
    self.transport.connect(username=self.username, password=self.password)
  def command(self, cmd): # 正常执行命令的连接 至此对象内容就既有执行命令的连接又有上传下载链接
    ssh = paramiko.SSHClient()
    ssh._transport = self.transport
    stdin, stdout, stderr = ssh.exec_command(cmd)
    result = stdout.read()
    return result
  def upload(self, local_path, remote_path):
    sftp = paramiko.SFTPClient.from_transport(self.transport)
    sftp.put(local_path, remote_path)
    sftp.close()
  def close(self):
    self.transport.close()
  def __enter__(self): # 对象执行with上下文会自动触发
    self.open()
    return self # 这里发挥上面with语法内的as后面拿到的就是什么 
  def __exit__(self, exc_type, exc_val, exc_tb): # with执行结束自动触发
    self.close()

使用流程

"""
上述的封装操作在使用的使用 必须按照下面的顺序
obj = SSHProxy(...)
obj.open() # 产生的对象必须要先执行open方法
obj.command('ls /')
obj.command('cat /data/tmp.txt')
obj.upload(...)
obj.upload(...)
obj.close()

利用文件操作的特性
f = open()
f.close()
嫌上述操作麻烦 利用with上下文做处理了
with open() as f:
  pass
as后面的值由__enter__方法返回值决定 返回什么就是什么

# 一旦对象被执行with会自动触发对象内部的__enter__方法 with结束之后还会自动触发__exit__方法
obj = SSHProxy(1,2,3,4)
with obj as f:
  pass

封装之后按照下面的方式使用即可

with SSHProxy(....) as obj:
  obj.command()
  obj.command()
  obj.upload()
  obj.upload()
  obj.command()
"""

拓展: __enter__ 和 __exit__ 的使用

class Foo(object):
  def __enter__(self):
    print('他进来了')
    return 123
  def __exit__(self, exc_type, exc_val, exc_tb):
    print('他就这么出去了')
obj = Foo()
with obj as f:
  print(f)
"""
执行结果:
他进来了
123
他就这么出去了
"""

总结:as后面的值由 __enter__ 方法返回值决定 返回什么就是什么,

​ 一旦对象被执行with会自动触发对象内部的 __enter__ 方法 with结束之后还会自动触发 __exit__ 方法

面试题

# 面试题"""
请在Context类中添加代码完成该类的实现(意思是怎么样修改才能实现以下代码并不会报错)
"""
class Context:
 pass
with Context() as ctx:
 ctx.do_something()
# 答案
class Context:
 def __enter__(self):
    return self
  def __exit__(self,*args,**kwargs):
    pass
 def do_something(self):
    pass

到此这篇关于python中使用paramiko模块并实现远程连接服务器执行上传下载功能的文章就介绍到这了,更多相关python paramiko模块内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Python 相关文章推荐
Python3实现的腾讯微博自动发帖小工具
Nov 11 Python
Python通过websocket与js客户端通信示例分析
Jun 25 Python
python中sys.argv参数用法实例分析
May 20 Python
Java多线程编程中ThreadLocal类的用法及深入
Jun 21 Python
python中的字典使用分享
Jul 31 Python
微信跳一跳python辅助软件思路及图像识别源码解析
Jan 04 Python
Python实现最常见加密方式详解
Jul 13 Python
Pycharm+django2.2+python3.6+MySQL实现简单的考试报名系统
Sep 05 Python
python 轮询执行某函数的2种方式
May 03 Python
python编写函数注意事项总结
Mar 29 Python
总结Python使用过程中的bug
Jun 18 Python
如何利用python实现Simhash算法
Jun 28 Python
vue学习笔记之动态组件和v-once指令简单示例
Feb 29 #Python
Python实现动态给类和对象添加属性和方法操作示例
Feb 29 #Python
Python使用type动态创建类操作示例
Feb 29 #Python
Django框架静态文件处理、中间件、上传文件操作实例详解
Feb 29 #Python
Python编程快速上手——强口令检测算法案例分析
Feb 29 #Python
Python编程快速上手——strip()函数的正则表达式实现方法分析
Feb 29 #Python
python通用读取vcf文件的类(复制粘贴即可用)
Feb 29 #Python
You might like
PHP的SQL注入过程分析
2012/01/06 PHP
PHP静态调用非静态方法的应用分析
2013/05/02 PHP
8个必备的PHP功能开发
2015/10/02 PHP
PHP读取大文件的几种方法介绍
2016/10/27 PHP
PHP+redis实现微博的拉模型案例详解
2019/07/10 PHP
基于Laravel 多个中间件的执行顺序详解
2019/10/21 PHP
浅析PHP中的 inet_pton 网络函数
2019/12/16 PHP
JavaScript类和继承 prototype属性
2010/09/03 Javascript
jQuery根据纬度经度查看地图处理程序
2013/05/08 Javascript
Jquery中$.get(),$.post(),$.ajax(),$.getJSON()的用法总结
2013/11/14 Javascript
浅谈js中用$(#ID)来作为选择器的问题(id重复的时候)
2017/02/14 Javascript
js实现复制功能(多种方法集合)
2018/01/06 Javascript
深入理解JS中Number(),parseInt(),parseFloat()三者比较
2018/08/24 Javascript
解决vue中虚拟dom,无法实时更新的问题
2018/09/15 Javascript
记React connect的几种写法(小结)
2018/09/18 Javascript
小程序云开发实战小结
2018/10/25 Javascript
vue通过video.js解决m3u8视频播放格式的方法
2019/07/30 Javascript
VUE实现密码验证与提示功能
2019/10/18 Javascript
js实现mp3录音通过websocket实时传送+简易波形图效果
2020/06/12 Javascript
[49:11]完美世界DOTA2联赛PWL S3 INK ICE vs DLG 第二场 12.20
2020/12/23 DOTA
关于Python中空格字符串处理的技巧总结
2017/08/10 Python
python机器学习理论与实战(二)决策树
2018/01/19 Python
python的xpath获取div标签内html内容,实现innerhtml功能的方法
2019/01/02 Python
python 弹窗提示警告框MessageBox的实例
2019/06/18 Python
Python 正则表达式 re.match/re.search/re.sub的使用解析
2019/07/22 Python
使用pyqt5 tablewidget 单元格设置正则表达式
2019/12/13 Python
python不使用for计算两组、多个矩形两两间的iou方式
2020/01/18 Python
Python批量处理csv并保存过程解析
2020/05/16 Python
python 实现 hive中类似 lateral view explode的功能示例
2020/05/18 Python
CSS3制作苹果风格键盘特效
2015/02/26 HTML / CSS
HTML5新增的8类INPUT输入类型介绍
2015/07/06 HTML / CSS
千禧酒店及度假村官方网站:Millennium Hotels and Resorts
2019/05/10 全球购物
JoJo Maman Bébé爱尔兰官网:英国最受欢迎的精品母婴品牌
2020/12/20 全球购物
面向对象编程的优势是什么
2015/12/17 面试题
公司领导班子对照检查存在问题整改措施
2014/10/02 职场文书
实验心得体会范文
2016/01/25 职场文书