博客
关于我
paramiko:ssh服务
阅读量:646 次
发布时间:2019-03-15

本文共 1077 字,大约阅读时间需要 3 分钟。

paramiko:ssh服务

paramiko是一个提供远程连接服务器功能的python包。

安装

pip install paramiko

示例

import paramikoimport osssh = paramiko.SSHClient()ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())# ip 端口 用户名 密码ssh.connect('192.168.1.2', 22, 'llk', 'llk123')#print(os.getcwd()) # 输出的是本地的地址# 传输文件。本地如果是放到当前文件夹就不必前缀了sftp = ssh.open_sftp()# 上传,put(localPath, remotePath)#sftp.put('file1.txt', '/home/pxy/test.txt')# 下载,get(remotePath, localPath)sftp.get('/home/pxy/test.txt', 'test.txt')# 关闭下载sftp.close()# 普通命令cmd = "mkdir joy"# 获取输出。不然是看不到的stdin, stdout, stderr = ssh.exec_command(cmd)# stdout.read()是byte类型,必须指定编码才能转成strprint("stdout:" + str(stdout.read(), encoding='utf-8') + "\n")print("stderr:" + str(stderr.read(), encoding='utf-8') + "\n")# 关闭连接ssh.close()

注意

一串命令(几个连续的ssh_exec_command)其实是无效的。因为每次执行命令都是新开线程,可以考虑管道,例如cmd1 | cmd2

但是cmd1 必须有正确输出,而 cmd2 必须可以处理 cmd2 的输出结果;而且 cmd2 只能处理 cmd1 的正确输出结果,不能处理 cmd1 的错误信息。
例如下面是可以正确查找到所需行的:

stdin, stdout, stderr = ssh.exec_command('cat joy/test.txt|grep-i"this"')print(str(stdout.read(),encoding='utf-8'))print(str(stderr.read(),encoding='utf-8'))

转载地址:http://rnelz.baihongyu.com/

你可能感兴趣的文章
Mysql悲观锁
查看>>
MySQL慢查询-开启慢查询
查看>>
MySQL慢查询分析和性能优化的方法和技巧
查看>>
MySQL慢查询日志总结
查看>>
Mysql慢查询日志,查询截取分析
查看>>
MySQL慢查询问题排查
查看>>
mysql截取sql语句
查看>>
mysql截取身份证号前几位_EXCEL中怎样截取身份证号前六位数字
查看>>
mysql手工注入
查看>>
MySQL执行SQL文件出现【Unknown collation ‘utf8mb4_0900_ai_ci‘】的解决方案
查看>>
Mysql执行update by id的过程
查看>>
mysql执行计划
查看>>
MySQL执行计划 EXPLAIN参数
查看>>
MySQL执行计划【explain】,看这一篇就够啦!
查看>>
Mysql执行计划字段解释
查看>>
mysql执行计划怎么看
查看>>
MySQL执行计划解读
查看>>
mysql执行顺序与索引算法
查看>>
mysql批量update优化_Mysql中,21个写SQL的好习惯,你值得拥有呀
查看>>
mysql批量update操作时出现锁表
查看>>