news 2026/4/18 6:24:19

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/4/15 7:23:18

基于STM32的汽车仪表系统设计

收藏和点赞,您的关注是我创作的动力 文章目录概要一、方案设计1.1 总体方案论证1.2 项目总体设计二、软件设计3.1 主程序设计三、软件设计3.3 emWin图形界面实现实物附录2 源程序清单四、 结论五、 文章目录概要 本次课题基于STM32F407微型控制器以及CAN总线通信技术…

作者头像 李华
网站建设 2026/4/17 14:04:15

电镀加工5大坑,千万避开最后1个!

电镀加工5大坑,千万避开最后1个!在塑胶、五金等制造业中,电镀加工是提升产品外观、增强耐腐蚀性和实现特定功能的关键工艺。然而,对于寻求外协加工的厂商而言,选择不当的电镀供应商可能带来一系列问题,轻则…

作者头像 李华
网站建设 2026/4/18 5:18:15

告别冗长推理:快速关闭Qwen3模型思考模式的实用指南

告别冗长推理:快速关闭Qwen3模型思考模式的实用指南 【免费下载链接】verl verl: Volcano Engine Reinforcement Learning for LLMs 项目地址: https://gitcode.com/GitHub_Trending/ve/verl 🚀 你是否遇到过Qwen3模型在生成回答时陷入"让我…

作者头像 李华
网站建设 2026/4/17 22:45:26

bugku——sqli-0x1

尝试万能和密码发现不行&#xff0c;查看源码。给了一个路径 /?pls_help<?php error_reporting(0); error_log(0);require_once("flag.php");function is_trying_to_hak_me($str) { $blacklist [" ", " ", ", "", "…

作者头像 李华
网站建设 2026/4/11 0:49:57

Mooncake AI平台实战指南:解锁语言模型服务的KVCache架构威力

Mooncake AI平台实战指南&#xff1a;解锁语言模型服务的KVCache架构威力 【免费下载链接】Mooncake 项目地址: https://gitcode.com/gh_mirrors/mo/Mooncake Mooncake AI平台作为Moonshot AI推出的革命性语言模型服务平台&#xff0c;以其独特的KVCache架构重新定义了…

作者头像 李华
网站建设 2026/4/3 6:02:06

text2vec-base-chinese中文语义匹配实战指南

text2vec-base-chinese中文语义匹配实战指南 【免费下载链接】text2vec-base-chinese 项目地址: https://ai.gitcode.com/hf_mirrors/shibing624/text2vec-base-chinese 你是否曾经遇到过这样的困扰&#xff1a;明明两个句子表达的是同一个意思&#xff0c;但计算机就是…

作者头像 李华