Skip to content

paramiko

paramiko是一个用于做远程控制的模块,使用该模块可以对远程服务器进行命令或文件操作,值得一说的是,fabric和ansible内部的远程管理就是使用的paramiko来现实。

1、下载安装

pycrypto,由于 paramiko 模块内部依赖pycrypto,所以先下载安装pycrypto

python
yum -y install python-devel
pip3 install pycrypto
pip3 install paramiko

2、模块使用

执行命令 - 用户名+密码

python
import paramiko

ssh = paramiko.SSHClient()
ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())
ssh.connect('172.16.0.10', 22, 'root', '123456')
stdin, stdout, stderr = ssh.exec_command('df -hT')
print(stdout.read().decode('utf-8'))    # 以utf-8编码对结果进行解码
ssh.close()

上传或下载文件 - 用户名+密码

python
# 上传文件
import os
import sys
import paramiko

t = paramiko.Transport(('172.16.0.19', 22))
t.connect(username='root', password='123456')
sftp = paramiko.SFTPClient.from_transport(t)
sftp.put('log.log', '/tmp/log.log')
t.close()

# 下载文件
import os,sys
import paramiko

t = paramiko.Transport(('172.16.0.19',22))
t.connect(username='root', password='123456')
sftp = paramiko.SFTPClient.from_transport(t)
sftp.get('/tmp/log.log', 'log2.log')
t.close()

执行命令 - 密匙

python
import paramiko

private_key_path = '/root/.ssh/id_rsa'
key = paramiko.RSAKey.from_private_key_file(private_key_path)

ssh = paramiko.SSHClient()
ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())
ssh.connect('172.16.0.19', 22, 'root', key)

stdin, stdout, stderr = ssh.exec_command('df -hT')
print(stdout.read())
ssh.close()

上传或下载文件 - 密匙

python
# 上传文件
import paramiko

pravie_key_path = '/root/.ssh/id_rsa'
key = paramiko.RSAKey.from_private_key_file(pravie_key_path)

t = paramiko.Transport(('172.16.0.19', 22))
t.connect(username='root', pkey=key)

sftp = paramiko.SFTPClient.from_transport(t)
sftp.put('log.log','/tmp/log.log')

t.close()

# 下载文件
import paramiko

pravie_key_path = '/root/.ssh/id_rsa'
key = paramiko.RSAKey.from_private_key_file(pravie_key_path)

t = paramiko.Transport(('172.16.0.19', 22))
t.connect(username='root', pkey=key)

sftp = paramiko.SFTPClient.from_transport(t)
sftp.get('/tmp/log.log', 'log3.log')

t.close()