python paramiko 使用

   python 下的paramiko功能很之強大。咱們所熟悉的Ansible就是用paramiko編寫。paramiko主要是經過ssh協議對遠程主機的管理。好比:執行遠程主機的CLI、上傳和下載文件等。python


1.經過使用paramiko 遠程管理主機nginx

 

#!/usr/bin/env python
#-*- coding:utf-8 -*-
#Author;David.Zhang
#Function:Remote management server using paramiko
import paramiko
def parserHost():
    HOSTS=['192.168.1.1', '192.168.1.2', '192.168.1.3']
    PORT=22
    USERNAME='root'
    PASSWD='xxxxxx'
    ld=[]
    for HOST in HOSTS:
        try:
            ssh = paramiko.SSHClient()
            ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())
            ssh.connect(hostname=HOST, username=USERNAME, password=PASSWD, port=PORT)
            stdin, stdout, stderr = ssh.exec_command('rpm -qa | grep nginx | md5sum')
            ssh.close()
        except:
            ld.append(HOST)
    return ld
if __name__ == "__main__":
    print parserHost()
#HOSTS   要處理的服務器列表
#ld      當某臺服務器處理異常,ld做爲buffer存放處理異常的服務器,方便排查錯誤。


2. 經過使用paramiko 上傳和下載文件
服務器

#!/usr/bin/env python
#-*- coding:utf-8 -*-
#Author:David.Zhang
import paramiko
def sftp():
    HOSTS=['192.168.1.1', '192.168.1.2']
    PORT=22
    USERNAME='root'
    PASSWD='xxxxx'
    ld=[]
    for HOST in HOSTS:
        try:
            ssh = paramiko.Transport((HOST,PORT))
            ssh.connect(username=USERNAME, password=PASSWD)
            sftp = paramiko.SFTPClient.from_transport(ssh)
            remotepath = '/root/file1'
            localpath = '/root/file1'
            sftp.put(localpath, remotepath)   #上傳
            sftp.get(remotpath, localpath)    #下載
            sftp.close()
        except:
            ld.append(HOST)
if __name__ == "__main__":
    print sftp()
相關文章
相關標籤/搜索