当前位置 主页 > 服务器问题 > win服务器问题汇总 >
前言
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()