博客
关于我
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/

你可能感兴趣的文章
Linux下的系统监控与性能调优:从入门到精通
查看>>
LiveGBS user/save 逻辑缺陷漏洞复现(CNVD-2023-72138)
查看>>
Mysql Can't connect to MySQL server
查看>>
MySQL InnoDB引擎的锁机制详解
查看>>
MySQL Xtrabackup 安装、备份、恢复
查看>>
mysql 优化器 key_mysql – 选择*和查询优化器
查看>>
MySQL 优化:Explain 执行计划详解
查看>>
mysql 修改默认字符集为utf8
查看>>
Mysql 共享锁
查看>>
mysql 写入慢优化
查看>>
mysql 创建表,不能包含关键字values 以及 表id自增问题
查看>>
mysql 判断表字段是否存在,然后修改
查看>>
MySQL 多表联合查询:UNION 和 JOIN 分析
查看>>
MySQL 大数据量快速插入方法和语句优化
查看>>
mysql 如何给SQL添加索引
查看>>
mysql 字段区分大小写
查看>>
mysql 字段类型类型
查看>>
MySQL 存储引擎
查看>>
mysql 更新子表_mysql 在update中实现子查询的方式
查看>>
mysql 自增id和UUID做主键性能分析,及最优方案
查看>>