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

你可能感兴趣的文章
mysql5.5最简安装教程
查看>>
mysql5.6 TIME,DATETIME,TIMESTAMP
查看>>
mysql5.6.21重置数据库的root密码
查看>>
Mysql5.6主从复制-基于binlog
查看>>
MySQL5.6忘记root密码(win平台)
查看>>
MySQL5.6的Linux安装shell脚本之二进制安装(一)
查看>>
MySQL5.6的zip包安装教程
查看>>
mysql5.7 for windows_MySQL 5.7 for Windows 解压缩版配置安装
查看>>
mysql5.7 安装版 表不能输入汉字解决方案
查看>>
MySQL5.7.18主从复制搭建(一主一从)
查看>>
MySQL5.7.19-win64安装启动
查看>>
mysql5.7.19安装图解_mysql5.7.19 winx64解压缩版安装配置教程
查看>>
MySQL5.7.37windows解压版的安装使用
查看>>
mysql5.7免费下载地址
查看>>
mysql5.7命令总结
查看>>
mysql5.7安装
查看>>
mysql5.7性能调优my.ini
查看>>
MySQL5.7新增Performance Schema表
查看>>
Mysql5.7深入学习 1.MySQL 5.7 中的新增功能
查看>>
Webpack 之 basic chunk graph
查看>>