python ssh模块stdout.read 和recv_Python操作远程服务器 paramiko模块详细介绍

前言

paramiko模块是基于Python实现的SSH远程安全连接,可以提供在远程服务器上执行命令、上传文件到服务器或者从指定服务器下载文件的功能。

paramiko模块安装方法

paramiko模块不是python自带的标准库,需要自行下载安装,建议使用pip自动安装。方法如下:

(1)配置pip命令和镜像源路径。如果已配置,跳过。

(2)执行pip install paramiko进行安装。出现successful字样表示安装完成。

paramiko常用函数介绍

SSHclient类

(1)ssh远程连接服务器,格式为:connect(hostname, port=22, username=None, password=None, pkey=None, key_filename=None, timeout=None, ...)。其中hostname表示主机IP,port表示ssh服务端口号,默认是22,username和password表示登录用户名和密码,timeout表示设置连接超时时长。

(2)远程主机没有本地主机密钥或HostKeys对象时的连接方法。格式为:set_missing_host_key_policy(policy)。其中policy

参数常见取值有3种,分别如下:

AutoAddPolicy:自动添加主机名及主机密钥到本地的known_hosts,不依赖load_system_host_key的配置。即新建立ssh连接时不需要再输入yes或no进行确认。最为常用。

WarningPolicy 用于记录一个未知的主机密钥的python警告。并接受,功能上和AutoAddPolicy类似,但是会提示是新连接。

RejectPolicy 自动拒绝未知的主机名和密钥,依赖load_system_host_key的配置。此为默认选项

(3)远程执行命令,函数格式:exec_command(command, bufsize=-1, timeout=None, get_pty=False, environment=None),该命令的输入与输出流为标准输入、标出输出、标准错误输出。

(4)在远程服务器上生成新的交互式shell。函数格式为:invoke_shell(term='vt100', width=80, height=24, width_pixels=0, height_pixels=0, environment=None)。

上述只是介绍了SSHclient类常用的几个函数。SSHclient类函数详细介绍参考SSHClient

SFTPClient类

(1)创建一个已连通的SFTP客户端通道,格式为:from_transport(cls,t)

(2)将本地文件上传到服务器,格式为:put(localpath, remotepath, callback=None, confirm=True)

(3)从服务器下载文件到本地,格式为:get(remotepath, localpath, callback=None)

(4)在服务器上创建目录,格式为:mkdir()

(5)在服务器上删除目录,格式为:remove()

(6)在服务器上重命名目录,格式为:rename()

(7) 查看服务器文件状态,格式为:stat()

(8)列出服务器目录下的文件,格式为:listdir()

paramiko常用场景

(1)在远程服务器执行命令,并获取命执行命令输出结果

import paramiko

ssh = paramiko.SSHClient()

ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())

ssh.connect(hostname='192.168.0.1', port=22, username='root', password='Aa12345!')

stdin, stdout, stderr = ssh.exec_command('df -k')

print stdout.read()

ssh.close()

(2)在远程服务器执行命令,并获取执行命令的结果码

import paramiko

ssh = paramiko.SSHClient()

ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())

ssh.connect(hostname='192.168.0.1', port=22, username='root', password='Aa12345!')

stdin, stdout, stderr = ssh.exec_command('df -k')

channel = stdout.channel

ret = channel.recv_exit_status()

if ret == 0:

print stdout.read()

else:

print stderr.read()

(3)在远程服务器执行命令,需要生成子进程并交互执行命令

import paramiko,time

ssh = paramiko.SSHClient()

ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())

ssh.connect(hostname='192.168.0.1', port=22, username='root', password='Aa12345!')

interact = conn.invoke_shell()

stdin, stdout, stderr = ssh.exec_command('df -k')

interact = conn.invoke_shell()

interact.send("sed -i '/192.168.0.2/d' /root/.ssh/known_hosts" + '\n')

time.sleep(1)

interact.send('ssh root@172.16.128.2' + '\n')

time.sleep(2)

interact.send('yes' + '\n')

time.sleep(2)

interact.send('Aa12345!' + '\n')

time.sleep(2)

interact.send('df -k!' + '\n')

result = interact.recv(65535)

print result

(4)上传文件到远程服务器

import paramiko

scp = paramiko.Transport(('192.168.0.1',22))

scp.connect(username='root',password='Aa12345!')

sftp=paramiko.SFTPClient.from_transport(scp)

local_path = "D:\\temp\\cc.txt"

remote_path = "/tmp/cc.txt"

sftp.put(local_path, remote_path)

scp.close()

(5)从远程服务器下载文件

import paramiko

scp = paramiko.Transport(('192.168.0.1',22))

scp.connect(username='root',password='Aa12345!')

sftp=paramiko.SFTPClient.from_transport(scp)

remote_path = "/tmp/aaaa.txt"

local_path = "D:\\temp\\aaaa.txt"

sftp.get(remote_path, local_path)

scp.close()

paramiko使用完整实例

import paramiko

def ssh_con(ip, username, password):

try:

con = paramiko.SSHClient()

con.set_missing_host_key_policy(paramiko.AutoAddPolicy())

con.connect(ip=ip, username=username, password=password, timeout=5)

except:

return None

else:

return con

def exec_cmd(conn, cmd):

interact = conn.invoke_shell()

interact.send(cmd)

result = interact.recv(65535)

return result

def exec_cmd2(conn,cmd):

stdin, stdout, stderr = conn.exec_command(cmd)

channel = stdout.channel

ret = channel.recv_exit_status()

if ret == 0:

return (ret, stdout.read())

else:

return (ret, stderr.read())

if __name__ == '__main__':

ip = '192.168.0.1'

user = 'root'

passwd = 'root'

con = ssh_con(ip, user, passwd)

if not con:

print "Connect %s fail,please check." % (ip,)

cmd = 'df -k'

ret, result = exec_cmd2(con,cmd)

print result

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Python 中可以使用 `paramiko` 模块来连接远程服务器,并使用 `subprocess` 模块来执行命令。判断 `sshpass` 服务是否存在,可以在远程服务器上执行 `sshpass -V` 命令,如果返回值为 0,则说明 `sshpass` 已经安装。如果返回值不为 0,则说明 `sshpass` 没有安装。 以下是一个示例代码: ```python import paramiko import subprocess # 连接远程服务器 ssh = paramiko.SSHClient() ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy()) ssh.connect('remote_host', username='username', password='password') # 检查 sshpass 是否已经安装 try: stdin, stdout, stderr = ssh.exec_command('sshpass -V') if stdout.channel.recv_exit_status() != 0: raise Exception('sshpass not found') except Exception as e: # 如果 sshpass 没有安装,则通过 yum 安装 print('sshpass not found, installing...') stdin, stdout, stderr = ssh.exec_command('yum -y install sshpass') if stdout.channel.recv_exit_status() != 0: print('install sshpass failed') print(stderr.read().decode('utf-8')) else: print('install sshpass success') else: print('sshpass already installed') # 关闭连接 ssh.close() ``` 在上述示例中,首先使用 `paramiko` 模块连接远程服务器。然后在远程服务器上执行 `sshpass -V` 命令检查 `sshpass` 是否已经安装。如果返回值不为 0,则说明 `sshpass` 没有安装,然后在远程服务器上执行 `yum -y install sshpass` 命令来安装 `sshpass`。如果安装成功,则输出 `install sshpass success`。如果安装失败,则输出 `install sshpass failed` 并输出安装日志。如果 `sshpass` 已经安装,则输出 `sshpass already installed`。最后关闭连接。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值