博客
关于我
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之分组查询GROUP BY,HAVING
查看>>
mysql之分页查询
查看>>
Mysql之备份与恢复
查看>>
mysql之子查询
查看>>
MySQL之字符串函数
查看>>
mysql之常见函数
查看>>
Mysql之性能优化--索引的使用
查看>>
mysql之旅【第一篇】
查看>>
Mysql之索引选择及优化
查看>>
mysql之联合查询UNION
查看>>
mysql之连接查询,多表连接
查看>>
mysql乐观锁总结和实践 - 青葱岁月 - ITeye博客
查看>>
mysql也能注册到eureka_SpringCloud如何向Eureka中进行注册微服务-百度经验
查看>>
mysql乱码
查看>>
Mysql事务。开启事务、脏读、不可重复读、幻读、隔离级别
查看>>
MySQL事务与锁详解
查看>>
MySQL事务原理以及MVCC详解
查看>>
MySQL事务及其特性与锁机制
查看>>