news 2026/1/26 20:24:06

Paramiko远程操作Linux服务器

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Paramiko远程操作Linux服务器

在日常工作中我们经常会跟Linux打交道,对于测试同学来说,使用Linux的场景还是比较多的,比如:搭建测试环境、查看日志信息、修改配置文件、监控服务资源等。

本篇将介绍一个Python的第三方库Paramiko,使用Paramiko,我们可以在Python脚本中进行SSH连接Linux服务器并远程执行Linux命令。

那么,我们为何要学习Paramiko呢,它可以解决什么问题呢,又能给我们日常工作带来什么呢?

在前文中说过,职场打工人学习技能和工具的很大原因是为了解决工作中遇到的某些具体问题,我们学习Paramiko当然也是为了解决某些问题。

例如要想在Linux服务器上进行测试环境的部署,传统的做法是使用SSH工具(例如:Xshell、Xftp、FinalShell、secureCRT、PuTTY等)连接远程服务器,然后手动在Linux服务器上输入一条一条的命令,最终完成测试环境的搭建。其实每次搭建环境所用的Linux命令几乎都是相同的,于是我们就可以借助Paramiko,将这些命令编写成Python脚本,进而实现自动搭建测试环境。并且还可以结合接口自动化以及UI自动化,完成部署、激活、数据初始化、自动化测试等一条龙服务,实现整个流程的自动化。

安装及使用
  1. 安装Paramiko库

    pip install paramiko
  2. 安装完成后,可以使用以下代码进行远程操作Linux服务器

    # author: 咖啡加剁椒 # datetime: 2023/5/28 17:16 # function: 远程操作Linux服务器demo import paramiko # 创建SSH客户端 client = paramiko.SSHClient() # 设置自动添加主机密钥 client.set_missing_host_key_policy(paramiko.AutoAddPolicy()) # 连接服务器 client.connect(hostname='服务器地址', port='端口', username='用户名', password='密码') # 执行远程命令 # 使用exec_command()方法执行远程命令,并使用stdout对象获取命令的输出、stderr对象获取命令的报错信息,可以根据需要对输出进行处理和显示 stdin, stdout, stderr = client.exec_command('你要执行的命令') # 获取命令输出 output = stdout.read().decode('utf-8') print(output) # 关闭连接 client.close()
一些坑
  • 运行时报错ModuleNotFoundError: No module named '_cffi_backend'

    出现这个错误通常是由于缺少cffi模块导致的,cffi是Paramiko库的一个依赖项,在安装Paramiko时会附带安装。但是,当我们尝试使用pip install cffi重新安装cffi模块时,又提示我们cffi库已经存在,此时的做法可以先使用pip uninstall cffi卸载已存在的库,然后重新执行pip install cffi

  • 使用cd命令进行目录切换时不生效

    当使用Paramiko库远程执行命令时,cd命令无法直接切换目录,这是因为cd是一个shell内置命令,无法直接通过Paramiko执行,此时可以通过在执行命令时添加额外的命令前缀来模拟cd命令的行为。

    PS:shell内置命令就是有bash shell自身提供的命令,而不是文件系统中的可执行脚本文件。

    可以使用type命令来确定一个命令是否是内置命令:

    二者的区别在于:内置命令执行速度快,内置命令是当前shell环境的一部分,就在当前进程内执行,减少了上下文切换;外部脚本文件执行速度慢,需要磁盘I/O操作,并且fork一个新的进程运行脚本文件,导致进行之间上下文切换。

    对于这种内置命令不生效的问题,我们的解决方案如下:

    # 切换目录 command = 'cd /opt && your_command' # 在目标目录中执行其他命令 stdin, stdout, stderr = client.exec_command(command)

    在上述示例中,使用了 && 运算符来在单个命令中组合 cd 命令和其他命令。&& 运算符表示只有在前一个命令成功执行后,才会执行后续的命令。因此,我们将 cd 命令和需要在目标目录中执行的其他命令连接在一起。

    在实际应用中,将 '/opt' 替换为想要切换到的实际目录,并将 'your_command' 替换为需要在该目录中执行的实际命令,例如:cd /opt && pwd

    通过类似的方法,可以模拟其他shell内置命令的行为,但并非所有的shell内置命令都能以这种方式执行,因为某些命令可能依赖于shell的上下文环境。

  • 使用wget命令下载文件时文件为0KB

    刚开始使用wget http://XXX/file.tar.gz下载文件时发现下载下来的文件为0KB,原因是在执行wget命令时,Python脚本挂起,解决方案就是在wget命令中添加一个超时,如下:

    wget -q -T90 http://XXX/file.tar.gz
  • 使用tar命令解压文件时报错gzip: stdin: unexpected end of file

    通常在使用wget命令下载文件压缩包后会使用tar命令对文件进行解压,但是在解压时报错。

    解决方案就是在wget和tar命令之间添加等待时间,如下:

    client.exec_command('wget -q -T90 http://XXX/file.tar.gz') time.sleep(5) # 添加等待时间 client.exec_command('tar -zxvf file.tar.gz -C /xxx')
将Paramiko封装成工具类

为了方便在不同的项目中引用,我们可以将Paramiko封装成工具类,如下:

# author: 咖啡加剁椒 # datetime: 2023/5/25 20:45 # function: 远程连接Linux服务器工具类封装 import paramiko class SSHUtils(): def __init__(self): try: # 创建SSH客户端 self.ssh = paramiko.SSHClient() # 允许连接不在known_hosts文件中的主机 self.ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy()) # 连接远程服务器 self.ssh.connect(hostname='', port=22, username='', password='') except: print('SSH连接异常……') def __del__(self): self.ssh.close() print('SSH connection closed.') def exe_cmd(self, cmd, info=True, error=True): """ 执行远程命令 :param cmd: 要执行的命令 :param info: 是否打印正确信息,默认为True :param error: 是否打印错误信息,默认为True :return: """ print('\n' + "=============== 开始执行命令 ===============" + '\n' + str(cmd)) stdin, stdout, stderr = self.ssh.exec_command(cmd) stdout = stdout.read().decode('utf-8') stderr = stderr.read().decode('utf-8') if stdout and info: print(stdout) elif stderr and error: print(stderr) print('\n' + "=============== 命令执行完成 ===============" + '\n' + str(cmd))

以上,完。

最后作为一位过来人也是希望大家少走一些弯路,在这里我给大家分享一些软件测试的学习资料和我花了3个月整理的软件测试自学全栈,这些资料希望能给你前进的路上带来帮助。

视频文档获取方式:
这份文档和视频资料,对于想从事【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴我走过了最艰难的路程,希望也能帮助到你!以上均可以分享,点下方小卡片即可自行领取。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/1/26 13:45:50

Rust使用IDE,除了vscode还有RustRover非商业用户可以免费使用

这两年写代码的时候,经常能看到 Rust 这个名字。以前更多是在一些系统工具或者小圈子里提到,现在不一样了,不管是区块链、后端服务,还是命令行工具,都有人在用 Rust。群里聊技术,Rust 基本隔一段时间就会被…

作者头像 李华
网站建设 2026/1/26 6:21:20

解决appium ui自动化无法识别悬浮窗问题

事情的起因是在两个项目上,A项目的虚浮窗按钮无法获取 B项目的推荐和看动态无法获取UI元素 通过adb shell dump也是无法获取到,但就一个问题,为啥weditor可以定位到呢? 那奇怪了是什么原因?为什么会突然有这个现象呢&a…

作者头像 李华
网站建设 2026/1/26 5:04:58

5G单兵图传

5G单兵图传设备是近年来随着5G技术的快速发展而兴起的一种高科技装备,它能够在应急救援领域发挥巨大的作用。4G/5G单兵远程传输终端,是用于解决无人机等设备自身携带图传系统距离近、无法满足跨区、跨市、跨省长距离指挥调度所定制的产品,内置…

作者头像 李华
网站建设 2026/1/26 5:04:56

Lemonade SDK终极指南:快速部署大型语言模型服务的完整教程

Lemonade SDK是一个专为简化大型语言模型服务而设计的强大工具包,它能够帮助开发者在CPU、GPU和NPU等多种硬件平台上高效部署和测试LLM应用。无论您是AI初学者还是经验丰富的开发者,lemonade都能为您提供一站式的本地LLM服务解决方案。 【免费下载链接】…

作者头像 李华
网站建设 2026/1/25 13:46:07

KolodaView开源贡献全攻略:从技术新手到社区核心贡献者

KolodaView开源贡献全攻略:从技术新手到社区核心贡献者 【免费下载链接】Koloda KolodaView is a class designed to simplify the implementation of Tinder like cards on iOS. 项目地址: https://gitcode.com/gh_mirrors/ko/Koloda 在当今快速发展的移动…

作者头像 李华