python中paramiko模塊的使用

paramiko

paramiko是一個用於作遠程控制的模塊,使用該模塊能夠對遠程服務器進行命令或文件操做,值得一說的是,fabric和ansible內部的遠程管理就是使用的paramiko來現實。python

一、下載安裝

pycrypto,因爲 paramiko 模塊內部依賴pycrypto,因此先下載安裝pycrypto服務器

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

二、模塊使用

執行命令 - 用戶名+密碼

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()

上傳或下載文件 - 用戶名+密碼

# 上傳文件
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()

執行命令 - 密匙

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()

上傳或下載文件 - 密匙

# 上傳文件
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()
相關文章
相關標籤/搜索