Python Paramiko库:SSH远程连接与文件传输实战指南

更多资料获取

📚 个人网站:ipengtao.com


在网络管理和系统运维中,SSH(Secure Shell)是一种广泛用于远程登录和文件传输的协议。Python中的Paramiko库为开发者提供了灵活、强大的SSH客户端和服务器功能。本文将深入探讨Paramiko库的使用,通过详细的示例代码,帮助读者理解如何在Python中进行SSH远程连接和文件传输。

安装Paramiko库

首先,确保已经安装了Paramiko库。可以使用以下命令进行安装:

pip install paramiko

SSH远程连接

使用Paramiko建立SSH远程连接的过程非常简单。

以下是一个基本的SSH连接示例:

import paramiko# 设置SSH连接参数
hostname = 'your_remote_host'
port = 22
username = 'your_username'
password = 'your_password'# 创建SSH客户端
client = paramiko.SSHClient()# 自动添加主机密钥
client.set_missing_host_key_policy(paramiko.AutoAddPolicy())# 连接远程主机
client.connect(hostname, port, username, password)# 执行远程命令
stdin, stdout, stderr = client.exec_command('ls -l')# 打印命令输出
print(stdout.read().decode())# 关闭SSH连接
client.close()

这个示例中,通过paramiko.SSHClient创建了一个SSH客户端,使用connect方法连接远程主机,然后通过exec_command方法执行了一个远程命令,并打印了命令的输出。

文件传输

Paramiko还提供了便捷的文件传输功能,可以轻松实现文件的上传和下载。

以下是一个文件上传的示例:

import paramiko# 设置SSH连接参数
hostname = 'your_remote_host'
port = 22
username = 'your_username'
password = 'your_password'# 创建SSH传输通道
transport = paramiko.Transport((hostname, port))
transport.connect(username=username, password=password)# 创建SFTP客户端
sftp = paramiko.SFTPClient.from_transport(transport)# 上传本地文件到远程主机
local_path = 'local_file.txt'
remote_path = 'remote_file.txt'
sftp.put(local_path, remote_path)# 关闭SFTP连接
sftp.close()# 关闭SSH传输通道
transport.close()

在这个示例中,通过paramiko.Transport创建了一个SSH传输通道,然后使用paramiko.SFTPClient从传输通道创建了一个SFTP客户端。通过put方法,我们将本地文件上传到远程主机。

进阶应用:使用SSH密钥进行连接

Paramiko还支持使用SSH密钥进行连接,提高了安全性。

以下是一个使用SSH密钥的连接示例:

import paramiko# 设置SSH连接参数
hostname = 'your_remote_host'
port = 22
username = 'your_username'
private_key_path = '/path/to/your/private/key'# 创建SSH客户端,加载私钥文件
private_key = paramiko.RSAKey(filename=private_key_path)
client = paramiko.SSHClient()# 自动添加主机密钥
client.set_missing_host_key_policy(paramiko.AutoAddPolicy())# 连接远程主机,使用SSH密钥进行身份验证
client.connect(hostname, port, username, pkey=private_key)# 执行远程命令
stdin, stdout, stderr = client.exec_command('ls -l')# 打印命令输出
print(stdout.read().decode())# 关闭SSH连接
client.close()

在这个示例中,使用paramiko.RSAKey加载了本地的私钥文件,并在连接时通过pkey参数指定了私钥。这样,就实现了使用SSH密钥进行连接的操作。

文件下载与目录同步

除了上传文件,Paramiko还支持从远程主机下载文件和同步目录。

以下是一个文件下载和目录同步的示例:

import paramiko# 设置SSH连接参数
hostname = 'your_remote_host'
port = 22
username = 'your_username'
password = 'your_password'# 创建SSH传输通道
transport = paramiko.Transport((hostname, port))
transport.connect(username=username, password=password)# 创建SFTP客户端
sftp = paramiko.SFTPClient.from_transport(transport)# 下载远程文件到本地
remote_file_path = 'remote_file.txt'
local_file_path = 'local_file.txt'
sftp.get(remote_file_path, local_file_path)# 同步远程目录到本地
remote_dir_path = 'remote_directory'
local_dir_path = 'local_directory'
sftp.get_r(remote_dir_path, local_dir_path)# 关闭SFTP连接
sftp.close()# 关闭SSH传输通道
transport.close()

在这个示例中,使用get方法将远程文件下载到本地,并使用get_r方法同步整个远程目录到本地。

多个命令的批量执行

Paramiko允许批量执行多个命令,这在一次SSH连接中执行多个任务时非常有用。

以下是一个批量执行多个命令的示例:

import paramiko# 设置SSH连接参数
hostname = 'your_remote_host'
port = 22
username = 'your_username'
password = 'your_password'# 创建SSH客户端
client = paramiko.SSHClient()
client.set_missing_host_key_policy(paramiko.AutoAddPolicy())
client.connect(hostname, port, username, password)# 定义多个要执行的命令
commands = ['ls -l','echo "Hello, World!"','df -h'
]# 执行多个命令
for command in commands:stdin, stdout, stderr = client.exec_command(command)print(f"Command: {command}")print(stdout.read().decode())# 关闭SSH连接
client.close()

这个示例中,定义了一个包含多个命令的列表,然后通过循环执行每个命令,逐一打印执行结果。

异常处理机制

在实际应用中,异常处理是保障代码稳定性和可靠性的关键部分。当涉及到远程连接、文件传输等网络操作时,异常处理尤为重要。以下是一些常见的异常处理场景和相应的处理方式:

1. 网络连接异常

import paramiko
from paramiko import SSHExceptiontry:# 尝试建立SSH连接client = paramiko.SSHClient()client.set_missing_host_key_policy(paramiko.AutoAddPolicy())client.connect('remote_host', username='username', password='password')# 执行其他操作...except SSHException as e:print(f"SSH Connection Error: {e}")finally:# 确保连接关闭if client:client.close()

2. 文件不存在异常(SFTP)

import paramiko
from paramiko import SFTPErrortry:transport = paramiko.Transport(('remote_host', 22))transport.connect(username='username', password='password')# 创建SFTP客户端sftp = paramiko.SFTPClient.from_transport(transport)# 尝试下载远程文件sftp.get('remote_file.txt', 'local_file.txt')except FileNotFoundError as e:print(f"File Not Found Error: {e}")finally:# 关闭SFTP连接if sftp:sftp.close()# 关闭SSH传输通道if transport:transport.close()

提高安全性:使用SSH密钥进行连接

明文密码在传输过程中存在安全风险,因此建议使用SSH密钥进行连接,提高安全性。以下是一个使用SSH密钥的连接示例:

import paramiko# 设置SSH连接参数
hostname = 'your_remote_host'
port = 22
username = 'your_username'
private_key_path = '/path/to/your/private/key'# 创建SSH客户端,加载私钥文件
private_key = paramiko.RSAKey(filename=private_key_path)
client = paramiko.SSHClient()# 自动添加主机密钥
client.set_missing_host_key_policy(paramiko.AutoAddPolicy())try:# 连接远程主机,使用SSH密钥进行身份验证client.connect(hostname, port, username, pkey=private_key)# 执行其他操作...except paramiko.AuthenticationException as e:print(f"Authentication Error: {e}")finally:# 关闭SSH连接client.close()

总结

在本文中,研究了Python中的Paramiko库,这是一款功能丰富的工具,用于实现SSH远程连接和文件传输。通过详细的示例代码,覆盖了从基本的SSH连接、文件上传和下载,到高级的目录同步、多命令批量执行等方面的应用场景。

为了保证代码的稳健性,强调了异常处理的重要性,特别是在涉及网络连接和文件操作时。通过合适的异常处理机制,能够更好地应对可能的错误情况,提高程序的可靠性。同时,在安全性方面,推荐了使用SSH密钥进行连接,而不是明文密码。这种做法不仅提高了远程连接的安全性,还有助于降低密码泄漏的风险。

总体而言,Paramiko库为Python开发者提供了强大的工具,使得处理SSH操作变得轻松而高效。通过深入理解并巧妙应用Paramiko的各项功能,开发者可以在网络管理、系统运维等方面取得更大的成就。


Python学习路线

在这里插入图片描述

更多资料获取

📚 个人网站:ipengtao.com

如果还想要领取更多更丰富的资料,可以点击文章下方名片,回复【优质资料】,即可获取 全方位学习资料包。

在这里插入图片描述
点击文章下方链接卡片,回复【优质资料】,可直接领取资料大礼包。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/219093.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

LeetCode刷题--- 验证二叉搜索树

个人主页:元清加油_【C】,【C语言】,【数据结构与算法】-CSDN博客 http://t.csdnimg.cn/ZxuNL个人专栏:力扣递归算法题 http://t.csdnimg.cn/ZxuNL 【C】 http://t.csdnimg.cn/c9twt 前言:这个专栏主要讲述递归递归、搜索与回溯算法&#x…

分享5款不起眼但非常实用的小工具

​ 时光荏苒,科技日新月异,一些看似不起眼的小工具却可能改变我们的工作方式。下面我们将介绍五款不可错过的小工具,它们能给你带来一些意想不到的效果,让你的工作更加高效便捷。 1.音乐播放——洛雪音乐助手 ​ 洛雪音乐助手是…

No module named ‘osgeo’解决办法

from osgeo import gdal 报错:No module named ‘osgeo’ pycharm安装osgeo、GDAL都失败 pip install osgeo失败 最后先下载对应版本的GDAL文件 再cmd命令行中用对应环境的python进行GDAL包安装 1.我将我的Anaconda某个环境文件夹D:\software\pinstall\Anaconda3…

Source Tree回滚 重置 贮藏操作

回滚提交 source tree的回滚提交: 在执行该操作时将会对history中提交的指定节点直接进行回滚,将该节点执行的提交操作撤销(如当前节点是提交文件,执行回滚提交时将会删除该文件,如果当前节点的前面的节点对该节点内容进行修改后,执行回滚提交时需要执行冲突解决),同时生成一次…

智能优化算法应用:基于蜻蜓算法3D无线传感器网络(WSN)覆盖优化 - 附代码

智能优化算法应用:基于蜻蜓算法3D无线传感器网络(WSN)覆盖优化 - 附代码 文章目录 智能优化算法应用:基于蜻蜓算法3D无线传感器网络(WSN)覆盖优化 - 附代码1.无线传感网络节点模型2.覆盖数学模型及分析3.蜻蜓算法4.实验参数设定5.算法结果6.参考文献7.MA…

【音视频 | H.264】H.264编码详解

😁博客主页😁:🚀https://blog.csdn.net/wkd_007🚀 🤑博客内容🤑:🍭嵌入式开发、Linux、C语言、C、数据结构、音视频🍭 🤣本文内容🤣&a…

使用FluentAvalonia组件库快速完成Avalonia前端开发

前言 工欲善其事必先利其器,前面我们花了几篇文章介绍了Avalonia框架以及如何在Avalonia框架下面使用PrismAvalonia完成MVV模式的开发。今天我们将介绍一款重磅级的Avalonia前端组件库,里面封装了我们开发中常用的组件,这样就不用我们自己再写组件了。专注业务功能开发,提…

1.4 Postman的安装

hello大家好,本小节我们来安装一下Postman,好为我们后续的测试工作做准备。 首先,打开Postman的官网Postman API Platform 然后根据同学们自己电脑的操作系统来下载对应的Postman安装包。我这里拿windows来举例。我们点击windows的图标 会跳…

常见的计算机图片格式

左rgb (光源色彩) 右cmyk (印刷色彩) 缺点,不能保存,储存空间太大

螺旋矩阵算法(leetcode第54题)

题目描述: 给你一个 m 行 n 列的矩阵 matrix ,请按照 顺时针螺旋顺序 ,返回矩阵中的所有元素。示例 1:输入:matrix [[1,2,3],[4,5,6],[7,8,9]] 输出:[1,2,3,6,9,8,7,4,5]示例 2:输入&#xff…

工厂设备维护管理有什么比较好的解决方案?有什么好用的工单管理系统?

生产设备对于工厂来说是十分宝贵的资产。一方面,工厂依赖设备进行生产活动,一旦设备故障就会影响产量;另一方面,工厂中的生产设备一般造价都比较高昂,如果出现故障就会增加工厂的生产成本;再一方面&#xf…

SQL Server 服务启动报错:错误1069:由于登录失败而无法启动服务

现象 服务器异常关机以后,SQL Server服务无法启动了。 启动服务时报错: 错误1069:由于登录失败而无法启动服务 解决办法 我的电脑–控制面板–管理工具–服务–右键MSSQLSERVER–属性–登录–登陆身份–选择"本地系统帐户" 设置完成后&am…

JavaSE基础50题:23. 数组拷贝(数组练习题)

文章目录 概述方法一:运用for循环进行拷贝方法二:Java内置方法进行拷贝方法三:指定区间进行拷贝方法四:数组克隆clone() 概述 数组拷贝。 注意: public static void main(String[] args) {int[] array1 {1,2,3,4};Sy…

Trace 在多线程异步体系下传递

JAVA 线程异步常见的实现方式有&#xff1a; new ThreadExecutorService 当然还有其他的&#xff0c;比如fork-join&#xff0c;这些下文会有提及&#xff0c;下面主要针对这两种场景结合 DDTrace 和 Springboot 下进行实践。 引入 DDTrace sdk <properties><java.…

JavaEE进阶学习: SpringBoot 日志文件

1.日志有什么用 日志的主要作用是记录系统的运行状态、事件和错误信息等。具体来说&#xff0c;日志可以用于以下几个方面&#xff1a; 故障排除&#xff1a;当系统出现故障或错误时&#xff0c;日志可以帮助开发人员定位问题的具体原因和位置&#xff0c;从而更快地修复系统。…

Intellij IDEA 运行maven报错误“CreateProcess error=2, 系统找不到指定的文件“的完美解决方案

一、问题背景 博主正常使用着Intellij IDEA&#xff0c;不知道为什么突然Intellij IDEA报错&#xff0c;错误提示如下&#xff1a; Error:Cannot run program "C:\Program Files\Java\jdk1.8.0_351" 观察Intellij IDEA报错的原因&#xff0c;我们可以知道&#xff1…

【LeetCode刷题-栈】-- 150.逆波兰表达式求值

150.逆波兰表达式求值 方法&#xff1a;使用栈 class Solution {public int evalRPN(String[] tokens) {Stack<Integer> numStack new Stack<>();for(int i 0; i < tokens.length;i){String token tokens[i];if(isNumber(token)){numStack.push(Integer.par…

免费!简单优雅的手机视频制作PR模板抖音素材下载

这是一款多功能的Premiere Pro模板&#xff0c;无论你是为视频、宣传内容还是社交媒体帖子短视频&#xff0c;这个pr模板都会为你的项目增添一丝优雅和专业。适用于广播&#xff0c;俱乐部&#xff0c;音乐会&#xff0c;舞蹈&#xff0c;设计&#xff0c;宣传片&#xff0c;动…

Qt/C++视频监控安卓版/多通道显示视频画面/录像存储/视频播放安卓版/ffmpeg安卓

一、前言 随着监控行业的发展&#xff0c;越来越多的用户场景是需要在手机上查看监控&#xff0c;而之前主要的监控系统都是在PC端&#xff0c;毕竟PC端屏幕大&#xff0c;能够看到的画面多&#xff0c;解码性能也强劲。早期的手机估计性能弱鸡&#xff0c;而现在的手机性能不…

外显记忆LLM

外显记忆 概念 概念 智能需要知识并且可以通过学习获取知识&#xff0c;这已促使大型深度建构的发展。然而&#xff0c;知识是不同的并且种类繁多。有些知识是隐含的、潜意识的并且难以用语言表达----比如怎么行走或狗与猫的样子有什么不同。其他知识可以是明确的、可陈述的以…