Python?Paramiko上傳下載sftp文件及遠程執(zhí)行命令詳解
一、簡介
Paramiko模塊是基于Python實現(xiàn)的SSH遠程安全連接,用于SSH遠程執(zhí)行命令、文件傳輸?shù)裙δ堋?/p>
安裝模塊
默認Python沒有自帶,需要手動安裝:
pip3 install paramiko
二、上傳文件
#!/usr/bin/env python3 # coding: utf-8 import paramiko def sftp_upload_file(host,user,password,server_path, local_path,timeout=10): """ 上傳文件,注意:不支持文件夾 :param host: 主機名 :param user: 用戶名 :param password: 密碼 :param server_path: 遠程路徑,比如:/home/sdn/tmp.txt :param local_path: 本地路徑,比如:D:/text.txt :param timeout: 超時時間(默認),必須是int類型 :return: bool """ try: t = paramiko.Transport((host, 22)) t.banner_timeout = timeout t.connect(username=user, password=password) sftp = paramiko.SFTPClient.from_transport(t) sftp.put(local_path, server_path) t.close() return True except Exception as e: print(e) return False
測試一下上傳,完整代碼如下:
#!/usr/bin/env python3 # coding: utf-8 import paramiko def sftp_upload_file(host, user, password, server_path, local_path, timeout=10): """ 上傳文件,注意:不支持文件夾 :param host: 主機名 :param user: 用戶名 :param password: 密碼 :param server_path: 遠程路徑,比如:/home/sdn/tmp.txt :param local_path: 本地路徑,比如:D:/text.txt :param timeout: 超時時間(默認),必須是int類型 :return: bool """ try: t = paramiko.Transport((host, 22)) t.banner_timeout = timeout t.connect(username=user, password=password) sftp = paramiko.SFTPClient.from_transport(t) sftp.put(local_path, server_path) t.close() return True except Exception as e: print(e) return False if __name__ == '__main__': host = '192.168.10.1' user = 'xiao' password = 'xiao@1234' server_path = '/tmp/tmp.txt' local_path = 'D:/text.txt' res = sftp_upload_file(host, user, password, server_path, local_path) if not res: print("上傳文件: %s 失敗"%local_path) else: print("上傳文件: %s 成功" % local_path)
執(zhí)行輸出:
上傳文件: D:/text.txt 成功
三、下載文件
def sftp_down_file(host,user,password,server_path, local_path,timeout=10): """ 下載文件,注意:不支持文件夾 :param host: 主機名 :param user: 用戶名 :param password: 密碼 :param server_path: 遠程路徑,比如:/home/sdn/tmp.txt :param local_path: 本地路徑,比如:D:/text.txt :param timeout: 超時時間(默認),必須是int類型 :return: bool """ try: t = paramiko.Transport((host,22)) t.banner_timeout = timeout t.connect(username=user,password=password) sftp = paramiko.SFTPClient.from_transport(t) sftp.get(server_path, local_path) t.close() return True except Exception as e: print(e) return False
測試一下,下載文件功能,完整代碼如下:
#!/usr/bin/env python3 # coding: utf-8 import paramiko def sftp_down_file(host,user,password,server_path, local_path,timeout=10): """ 下載文件,注意:不支持文件夾 :param host: 主機名 :param user: 用戶名 :param password: 密碼 :param server_path: 遠程路徑,比如:/home/sdn/tmp.txt :param local_path: 本地路徑,比如:D:/text.txt :param timeout: 超時時間(默認),必須是int類型 :return: bool """ try: t = paramiko.Transport((host,22)) t.banner_timeout = timeout t.connect(username=user,password=password) sftp = paramiko.SFTPClient.from_transport(t) sftp.get(server_path, local_path) t.close() return True except Exception as e: print(e) return False if __name__ == '__main__': host = '192.168.10.1' user = 'xiao' password = 'xiao@1234' server_path = '/tmp/tmp.txt' local_path = 'D:/text.txt' res = sftp_down_file(host, user, password, server_path, local_path) if not res: print("下載文件: %s 失敗"%server_path) else: print("下載文件: %s 成功" % server_path)
執(zhí)行輸出:
下載文件: /tmp/tmp.txt 成功
四、遠程執(zhí)行命令
def ssh_exec_command(host,user,password, cmd,timeout=10): """ 使用ssh連接遠程服務器執(zhí)行命令 :param host: 主機名 :param user: 用戶名 :param password: 密碼 :param cmd: 執(zhí)行的命令 :param seconds: 超時時間(默認),必須是int類型 :return: dict """ result = {'status': 1, 'data': None} # 返回結果 try: ssh = paramiko.SSHClient() # 創(chuàng)建一個新的SSHClient實例 ssh.banner_timeout = timeout # 設置host key,如果在"known_hosts"中沒有保存相關的信息, SSHClient 默認行為是拒絕連接, 會提示yes/no ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy()) ssh.connect(host, 22, user, password, timeout=timeout) # 連接遠程服務器,超時時間1秒 stdin, stdout, stderr = ssh.exec_command(cmd,get_pty=True,timeout=timeout) # 執(zhí)行命令 out = stdout.readlines() # 執(zhí)行結果,readlines會返回列表 # 執(zhí)行狀態(tài),0表示成功,1表示失敗 channel = stdout.channel status = channel.recv_exit_status() ssh.close() # 關閉ssh連接 # 修改返回結果 result['status'] = status result['data'] = out return result except Exception as e: print(e) print("錯誤, 登錄服務器或者執(zhí)行命令超時!!! ip: {} 命令: {}".format(ip,cmd))return False
測試一下,遠程執(zhí)行命令功能,完整代碼如下:
#!/usr/bin/env python3 # coding: utf-8 import paramiko def ssh_exec_command(host,user,password, cmd,timeout=10): """ 使用ssh連接遠程服務器執(zhí)行命令 :param host: 主機名 :param user: 用戶名 :param password: 密碼 :param cmd: 執(zhí)行的命令 :param seconds: 超時時間(默認),必須是int類型 :return: dict """ result = {'status': 1, 'data': None} # 返回結果 try: ssh = paramiko.SSHClient() # 創(chuàng)建一個新的SSHClient實例 ssh.banner_timeout = timeout # 設置host key,如果在"known_hosts"中沒有保存相關的信息, SSHClient 默認行為是拒絕連接, 會提示yes/no ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy()) ssh.connect(host, 22, user, password, timeout=timeout) # 連接遠程服務器,超時時間1秒 stdin, stdout, stderr = ssh.exec_command(cmd,get_pty=True,timeout=timeout) # 執(zhí)行命令 out = stdout.readlines() # 執(zhí)行結果,readlines會返回列表 # 執(zhí)行狀態(tài),0表示成功,1表示失敗 channel = stdout.channel status = channel.recv_exit_status() ssh.close() # 關閉ssh連接 # 修改返回結果 result['status'] = status result['data'] = out return result except Exception as e: print(e) print("錯誤, 登錄服務器或者執(zhí)行命令超時!!! ip: {} 命令: {}".format(ip,cmd)) return False if __name__ == '__main__': host = '192.168.10.1' user = 'xiao' password = 'xiao@1234' cmd = "cat /etc/issue | awk '{print $1,$2,$3}'" res = ssh_exec_command(host, user, password, cmd) # print(res) if not res or not res['data'] or res['status'] != 0: print("錯誤, ip: {} 執(zhí)行命令: {} 失敗".format(host, cmd), "red") exit() value = res['data'][0].strip() # 獲取實際值 print("操作系統(tǒng)為: %s"%value)
執(zhí)行輸出:
操作系統(tǒng)為: Ubuntu 16.04.2 LTS
五、錯誤集錦
1. EllipticCurvePublicKey.public_bytes
Please use EllipticCurvePublicKey.public_bytes to obtain both compressed and uncompressed point encoding.
原因
paramiko 2.4.2 依賴 cryptography,而最新的cryptography==2.5里有一些棄用的API。
解決
刪掉cryptography,安裝2.4.2,就不會報錯了。
pip uninstall cryptography pip install cryptography==2.4.2
本文參考鏈接:http://www.dbjr.com.cn/article/257218.htm
2. Error reading SSH protocol banner
Traceback (most recent call last):
File "/python3/lib/python3.5/site-packages/paramiko/transport.py", line 1966, in run
self._check_banner()
File "/python3/lib/python3.5/site-packages/paramiko/transport.py", line 2143, in _check_banner
"Error reading SSH protocol banner" + str(e)
paramiko.ssh_exception.SSHException: Error reading SSH protocol banner
Error reading SSH protocol banner
要解決這個問題, 需要將paramiko的響應等待時間調長。 修改paramiko/transport.py文件中的
self.banner_timeout
值, 將其設為300或者其他較長的值即可解決這個問題。
以上就是Python Paramiko上傳下載sftp文件及遠程執(zhí)行命令示例的詳細內容,更多關于Python Paramiko上傳下載sftp的資料請關注腳本之家其它相關文章!
相關文章
python3.7 openpyxl 刪除指定一列或者一行的代碼
這篇文章主要介紹了python3.7 openpyxl 刪除指定一列或者一行,文中通過代碼給大家介紹了python3 openpyxl基本操作,代碼簡單易懂,需要的朋友可以參考下2019-10-10使用PyTorch構建神經(jīng)網(wǎng)絡的操作指南
PyTorch 是一個在研究領域廣泛使用的深度學習框架,提供了大量的靈活性和效率,本文將向你介紹如何使用 PyTorch 構建你的第一個神經(jīng)網(wǎng)絡,感興趣的小伙伴可以參考閱讀2023-07-07python的xpath獲取div標簽內html內容,實現(xiàn)innerhtml功能的方法
今天小編就為大家分享一篇python的xpath獲取div標簽內html內容,實現(xiàn)innerhtml功能的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-01-01NumPy.npy與pandas DataFrame的實例講解
今天小編就為大家分享一篇NumPy.npy與pandas DataFrame的實例講解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-07-07Python中利用ItsDangerous快捷實現(xiàn)數(shù)據(jù)加密
這篇文章主要介紹了Python中利用ItsDangerous快捷實現(xiàn)數(shù)據(jù)加密,通過使用Python庫ItsDangerous,我們就可以高效快捷地完成數(shù)據(jù)加密/解密的過程,本文結合實例代碼給大家講解的非常詳細,需要的朋友可以參考下2022-11-11Pytorch實現(xiàn)基于CharRNN的文本分類與生成示例
今天小編就為大家分享一篇Pytorch實現(xiàn)基于CharRNN的文本分類與生成示例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-01-01Python實現(xiàn)監(jiān)控Nginx配置文件的不同并發(fā)送郵件報警功能示例
這篇文章主要介紹了Python實現(xiàn)監(jiān)控Nginx配置文件的不同并發(fā)送郵件報警功能,涉及Python基于difflib模塊的文件比較及smtplib模塊的郵件發(fā)送相關操作技巧,需要的朋友可以參考下2019-02-02