python Paramiko的SSH用法

Paramiko是Python中实现SSH协议的库,用于自动化远程服务器管理。首先通过pip install paramiko安装;然后使用SSHClient创建连接,可基于用户名密码或私钥认证连接远程主机;执行命令用exec_command获取stdin、stdout、stderr三个通道,输出需decode转字符串;支持SFTP文件传输,通过open_sftp获得SFTP客户端进行上传下载及目录操作;为提升效率,可封装SSHConnection类复用连接;生产环境中应避免AutoAddPolicy,推荐手动验证主机密钥并做好异常处理。

python paramiko的ssh用法

使用Python的Paramiko库进行SSH操作是自动化服务器管理、远程执行命令和文件传输的常用方式。Paramiko是SSHv2协议的Python实现,支持客户端和服务端功能,这里主要介绍作为SSH客户端连接远程Linux服务器的基本用法。

安装Paramiko

在使用前需先安装Paramiko:

pip install paramiko

连接SSH并执行命令

通过用户名和密码连接远程主机,并执行简单命令:

import paramiko

创建SSH客户端

ssh = paramiko.SSHClient()

立即学习“Python免费学习笔记(深入)”;

自动添加目标主机密钥(不推荐用于生产环境)

ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())

连接远程服务器

ssh.connect(‘192.168.1.100′, port=22, username=’user’, password=’pass’)

执行命令

stdin, stdout, stderr = ssh.exec_command(‘ls -l /tmp’)

获取输出结果

print(stdout.read().decode())print(stderr.read().decode()) # 错误信息

关闭连接

ssh.close()

说明:exec_command 返回三个通道对象,分别对应输入、正常输出和错误输出。stdout.read() 返回字节流,需 decode 转为字符串。

使用私钥登录(免密)

更安全的方式是使用SSH密钥对认证:

import paramiko

ssh = paramiko.SSHClient()ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())

使用私钥文件(如 id_rsa)

private_key = paramiko.RSAKey.from_private_key_file(‘/path/to/id_rsa’)

ssh.connect(‘192.168.1.100′, username=’user’, pkey=private_key)

stdin, stdout, stderr = ssh.exec_command(‘df -h’)print(stdout.read().decode())

ssh.close()

支持 DSA、ECDSA、Ed25519 等多种密钥类型,例如 Ed25519Key.from_private_key_file。

SFTP 文件上传下载

Paramiko也支持SFTP文件操作:

import paramiko

ssh = paramiko.SSHClient()ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())ssh.connect(‘192.168.1.100′, username=’user’, password=’pass’)

创建SFTP会话

sftp = ssh.open_sftp()

下载文件

sftp.get(‘/remote/file.txt’, ‘/local/file.txt’)

上传文件

sftp.put(‘/local/file.txt’, ‘/remote/file.txt’)

列出远程目录

files = sftp.listdir(‘/remote/dir/’)print(files)

sftp.close()ssh.close()

open_sftp() 返回一个SFTP客户端对象,可用于文件管理。

保持长连接与复用通道

频繁连接效率低,可复用SSH连接:

import paramiko

class SSHConnection:def init(self, host, port, user, password):self.host = hostself.port = portself.user = userself.password = passwordself.ssh = None

def connect(self):    self.ssh = paramiko.SSHClient()    self.ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())    self.ssh.connect(self.host, self.port, self.user, self.password)def exec_cmd(self, command):    stdin, stdout, stderr = self.ssh.exec_command(command)    return stdout.read().decode(), stderr.read().decode()def close(self):    if self.ssh:        self.ssh.close()

使用示例

client = SSHConnection(‘192.168.1.100’, 22, ‘user’, ‘pass’)client.connect()out, err = client.exec_cmd(‘uptime’)print(out)client.close()

封装类便于在多个操作中复用连接,提升效率。

基本上就这些。连接时注意异常处理(如AuthenticationException、SSHException),生产环境避免使用 AutoAddPolicy,应验证主机密钥。Paramiko功能完整,适合写运维脚本或集成到项目中。

以上就是python Paramiko的SSH用法的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1375831.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月14日 15:22:15
下一篇 2025年12月14日 15:22:23

相关推荐

发表回复

登录后才能评论
关注微信