paramiko

*paramiko需要PyCrypto模块的支持

paramiko支持通过SSH协议进行一些操作,比如远程执行命令,上下传文件等等

用法:

①  远程命令

ssh =paramiko.SSHClient()

ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())#指定当对方主机没有本机公钥的情况时应该怎么办,AutoAddPolicy表示自动在对方主机保存下本机的秘钥

ssh.connect('ip',22,'user','passwd') #SSH端口默认22,可改

stdin,stdout,stderr = ssh.exec_command("命令内容") #这三个得到的都是类文件对象

outmsg,errmsg = stdout.read(),stderr.read() #读一次之后,stdout和stderr里就没有内容了,所以一定要用变量把它们带的信息给保存下来,否则read一次之后就没有了

if errmsg == "":printoutmsg

ssh.close()

②  文件交流

tra = paramiko.Transport(('ip',22)) #参数是一个tuple

tra.connect(username='...',password='...') #一定要指明参数名的username和password。否则会报错str has no attribute 'get_name'

sftp =paramiko.SFTPClient.from_transport(tra)

sftp.put('本地路径','远程路径') #上传文件

sftp.get('远程路径','本地路径') #下载文件

tra.close()

需要注意的是在put和get方法中,两个路径都是需要完整的(要带文件名!)

sftp的put和get方法还有callback这个参数。这个参数指定一个函数对象,这个函数应该接受两个int型参数,分别代表了已上传/已下载的字节数;总的要上传/下载的字节数。利用callback的指定可以做出一个类似进度条的功能。另外,还需要注意的是callback会在传输完成之前不断地被调用但是具体是怎么样的时机下调用我不是很清楚,需要研究下paramiko的源码。但是可以确定的一点是这个callback函数也是在主线程中调用的,所以最好不要在里面写什么sleep,这样会导致整个传输过程变慢的。

■  Transport的更多扩展

今天想通过python做一个SSH模拟终端。想法非常简单,就是通过SSHClient类建立连接然后进行命令和返回的交互嘛。不过发生了很多问题,去网上一找才发现,原来SSHClient类的exec_command方法是个单session包装的方法。即调用这个方法只能执行一趟命令,执行完成之后就断开了连接,再次执行时又是新的session。比如:

ssh.exec_command('cd /tmp;pwd')的返回是/tmp,但如果把cd和pwd分成两个exec_command写的话,pwd最终返回的是HOME目录,这表明了exec_command的单会话特性。那么怎么样才能从更底层开始建立命令交互的通信? 网上小查了一种方法还是需要Transport这个我们之前在SFTP时候用的类。

做法:

tran = paramiko.Transport(sock=(ip,22))

tran.connect(username='xxx',password='xxx')

channel=tran.open_session()

channel.get_pty()

channel.invoke_shell()

channel.send('ls\n')

result= ''

whileTrue:

time.sleep(0.5)

res= channel.recv(65535).decode('utf8')

result+=resifresult:

sys.stdout.write(result.strip('\n'))if res.endswith('#') or res.endswith('$'):break

通过这样的方式搭建出来的一个SSH命令通道是和Xshell这种软件建立出来的终端差不多的,比如有终端命令行提示符,也支持cd等命令。

在获取命令运行的返回(recv方法的返回)时,我们用了一个while True的逐次取数据的方式。这么做的一个好处就是当返回比较多比较大的时候可以顺利读取完全。其实这么写也是有其必要性在里面的。如果直接在这个代码的循环外面直接recv一下,返回得到的会是'\r\n'而不是ls返回的文件信息。什么原理不清楚但是既然while True这个方式有必要性又有优点的话就可以考虑用下。

跳出循环的方式是判断返回的结尾是不是终端命令提示符的结尾#+"空格"或者$+"空格",这种判断方法比较不健壮。网上也有用正则匹配或者其他的一些方法来识别返回结果读取到头了,可参考。这种方法建立的SSH通道的话,是自带命令行提示符的,而且每条命令的返回实质上是“真的返回”+"\n"+"命令提示符",所以可以做到每一个命令返回之后后面就有命令提示符。

另一方面,这个通道也并不是很万能的,比如对通过stdin进行交互要怎么做目前我还没有找到办法、因此也就也意味着对vim,crontab -e之类的对交互有需求的软件就不是支持很好了。

■  更多扩展

●  在connect方法里还有参数timeout = float设置连接超时时间

在connect方法中,还可用参数pkey指定本机私钥文件用于身份验证,内容可以是个PKey类对象。也可以用key_filename = '路径' 这个参数来指定一个文件。而在SSHClient类还有方法load_system_host_keys用于指定对方主机存放本机公钥的位置,默认不加参数的话是将这个位置设置为~/.ssh/known_hosts。SSHClient类对象connect之前,先用load_system_host_keys指定本机公钥存放位置,再在connect的时候指明本机私钥的话,就不用password,只要username就可以登录了。

●  关于set_missing_host_key_policy

这个方法的参数有三种选择,分别对应三种当对方主机没有在相关文件中找到本机的公钥时做的动作:

paramiko.AutoAddPolicy()  自动添加本机的公钥和主机名进相关文件

paramiko.RejectPolicy()  自动拒绝未知的主机名和密钥,“未知”指的是没有在相关文件中有记录的主机

paramiko.WarningPolicy()  和AutoAdd没差,只不过在出现没有记录的情况时警告一下

●  SFTPClient类除了上面提到的那些方法以外,还有:

sftp.mkdir('路径',mode)  #mode不用加引号,直接写755之类的即可,方法直接创建目录并按mode设置其权限

sftp.remove('路径')  #删除某目录

sftp.stat("文件路径")  #获取文件信息

sftp.listdir("路径")  #以列表方式返回目录下的内容

以上这些方法和exec_command执行一些特定的命令是差不多的,实践的时候也不必一棵树吊死在exec_command上,也可以适当考虑这些方法。

●  ssh.exec_command的异步原理

据我估计ssh.exec_command应该是单独开一条线程来远程执行命令,而当我们对命令的输出不感兴趣,在exec_command执行之后不调用read来收集远程返回的信息的话,那么这个线程是不阻塞的。这是个小坑的地方。比如下面两个例子,ssh是一个已经配置好的SSHClient对象:

stdin,stdout,stderr = ssh.exec_command("sleep 5s;echo foo")

stdin,stdout,stderr= ssh.exec_command("echo bar")

out,err=stdout.read(),stderr.read()iferr:printerrelse:printout#这种情况下的输出只有bar######另一种情况######

stdin,stdout,stderr = ssh.exec_command("sleep 5s;echo foo")

out,err=stdout.read(),stderr.read()

stdin,stdout,stderr= ssh.exec_command("echo bar")

out,err=stdout.read(),stderr.read()iferr:printerrelse:printout#这种情况下先等5秒然后输出foo和bar

可以看到第一种情况中,没有读取stdout等的信息,那么本地程序直接往下执行,不管之前的命令是否还未给出结果,而第二种情况,由于我要读取内容,所以必须等到上一条命令执行完成给出结果本地才继续跑下一条命令。

●  stdin的用法

之前由于基本上都是从服务器上面读数据,对于stdin这个变量一直感觉很鸡肋。直到那天要批量改服务器密码。。试了一下果然stdin是可以拿来进行write的。记得在write的时候要适当插入回车\n来模拟敲回车的过程,否则很可能会出现SSH被堵塞的情况。比如改密码这个过程:

##前面配置过程省略##

stdin,stdout,stderr = ssh.exec_command("passwd")

stdin.write("old_password\nnew_password\nnew_password\n") #因为密码要确认,所以要输两遍

out,err =stdout.read(),stderr.read()if err != '':printerrelse:print out

python paramiko长连接_【Python】 SSH连接的paramiko相关推荐

  1. python远程连接ssh_Python实现SSH连接远程服务器

    首先需要安装paramiko模块 #-*- coding:utf-8 -*- __author__ = "MuT6 Sch01aR" import paramiko ssh = p ...

  2. 远程mysql用ssh连接_使用SSH密钥连接到远程MySQL服务器

    远程mysql用ssh连接 In this article, it will be described how to connect to remote MySQL Server on Linux O ...

  3. python实现长截图_用 Python 实现长截图拼接

    用 Python 实现长截图拼接 可能很多安卓手机都会自带拼接长截图的功能, 可是对于 iOS 只能通过第三方的 app 拼接了于是我想将拼接的功能做成微信小程序, 这样会比较方便, 无奈实现过程中发 ...

  4. pycharm远程连接服务器防止ssh连接中断

    pycharm远程连接服务器 1.安装pycharm专业版 2.打开实例,拿到用户名和密码 例如ssh -p 38076 root@region-1.autodl.com 密码:xxxxxxx 380 ...

  5. python作用域的顺序_“Python”函数的参数和范围,及其,作用域

    1. 参数类型 1.1 位置参数 显然对位置和顺序有要求,形参和实参必须一一对应,不可或缺 def show(msg): print(msg) s = "I love you!" ...

  6. python输出文本居中_#python PIL ImageDraw text 文本居中#

    python pip pil有什么东西 你所问的问题实是属1.先参考[教程]Python中的内置的和方的模块搞懂PIL是属于第三方Python模块2.再参考:[待完善][总结]Python安装第三方的 ...

  7. python多进程编程实例_[python] Python多进程编程技术实例分析

    这篇文章主要介绍了Python多进程编程技术,包括了线程.队列.同步等概念及相关的技巧总结,需要的朋友可以参考下 本文以实例形式分析了Python多进程编程技术,有助于进一步Python程序设计技巧. ...

  8. python查看excel编码格式_[Python]实现处理读写xlsx xls excel文件格式(含中文处理方法)...

    最近有个需求要处理excel 格式的数据,数据量比较大.用传统的语言似乎不太好处理,于是改用python实现,这里记录一下实现过程. 首先,科普一下xlsx xls的excel文件区别是什么. xls ...

  9. python快速爬虫视频_“python怎么快速爬虫视频“python 爬网页视频教程

    用python怎样爬网页 # coding:utf8 import cookielib import urllib2 url = "http://blog.uouo123.com" ...

  10. python朋友圈刷屏_“Python太火了!请救救Java!”9万程序员刷屏朋友圈 !

    没想到有生之年,笔者能观察到"霸主陨落"的过程,继PLPY4月榜单官宣,Python躺赢,再度"夺"冠,实力甩下Java和C后,近期,Stack Overflo ...

最新文章

  1. leetcode - 150. Evaluate Reverse Polish Notation
  2. 文件html怎么另存为wps,WPS文字中另存为功能详解(wps文字怎么保存到指定文件夹)...
  3. 如何写出健壮的代码?
  4. [数分提高]2014-2015-2第7教学周第2次课 (2015-04-16)
  5. [转载] 百科全说——栾加芹:你适合这些食物吗?(11-03-07)
  6. kotlin访问控制符可见性
  7. 如何使用echo指令向文件写入内容
  8. cdlinux之U盘启动cdlinux破解wifi(计算机系破解无线密码的方式 就不使用wifi万能钥匙了)-- 没有发现无线网卡
  9. jquery 实现抽奖小程序
  10. 软路由安装openwrt系统
  11. Python Flask Web 框架入门
  12. zippo蚀刻计算机键盘,【图片】蚀刻机自己填漆【zippo吧】_百度贴吧
  13. 18本生物竞赛辅导书
  14. linux 只读文件 删除,linux – 我无法删除文件’rm:无法删除X只读文件系统’
  15. 卸载win10自带的OneNote
  16. 【GANs学习笔记】(二)GANs大家族分类
  17. CSS .class .class与.class.class区别
  18. 基于asp.net网上论坛BBS毕业设计
  19. Kali Linux渗透测试 126 拒绝服务--Smurf 攻击
  20. 微视网媒:万亿城配的变局者,罗戈网专访绿色慧联总经理杨东

热门文章

  1. Ionic发布成android
  2. wp8.1 Study11:APP里文件读写和使用XML和Json序列化
  3. thinking in java -- notes-2
  4. EntityModelStudio系列教程2--静态建模之实体模型设计
  5. 神经网络-损失函数:
  6. 解决问题 com.alibaba.fastjson.JSONObject cannot be cast to xxx
  7. Leetcode--461. 汉明距离
  8. layui表头样式_layui中table表头样式修改方法
  9. java 设计方法_java 中如何处理设计一个方法
  10. python与办公自动化专业就业方向_Python最好的几大就业方向与岗位技能要求【行业风向】...