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