網站首頁 編程語言 正文
1.簡單版
# coding: utf-8 import paramiko import re from time import sleep def ssh(): ssh = paramiko.SSHClient() ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy()) #指定當對方主機沒有本機公鑰的情況時應該怎么辦,AutoAddPolicy表示自動在對方主機保存下本機的秘鑰 ssh.connect('172.16.1.5',22,'linyouyi','123456') #SSH端口默認22,可改 stdin,stdout,stderr = ssh.exec_command("df -hl") #這三個得到的都是類文件對象 outmsg,errmsg = stdout.read(),stderr.read() #讀一次之后,stdout和stderr里就沒有內容了,所以一定要用變量把它們帶的信息給保存下來,否則read一次之后就沒有了 #outmsg = str(outmsg) #print(outmsg.replace("\\n","\\r\\n")) print(outmsg.decode()) print(errmsg) if errmsg == "": print(outmsg) ssh.close() if __name__ == '__main__': ssh()
2.封裝版
# coding: utf-8 import paramiko import re from time import sleep # 定義一個類,表示一臺遠端linux主機 class Linux(object): # 通過IP, 用戶名,密碼,超時時間初始化一個遠程Linux主機 def __init__(self, ip, username, password, timeout=30): self.ip = ip self.username = username self.password = password self.timeout = timeout # transport和chanel self.t = '' self.chan = '' # 鏈接失敗的重試次數 self.try_times = 3 # 調用該方法連接遠程主機 def connect(self): while True: # 連接過程中可能會拋出異常,比如網絡不通、鏈接超時 try: self.t = paramiko.Transport(sock=(self.ip, 22)) self.t.connect(username=self.username, password=self.password) self.chan = self.t.open_session() self.chan.settimeout(self.timeout) self.chan.get_pty() self.chan.invoke_shell() # 如果沒有拋出異常說明連接成功,直接返回 print(u'連接%s成功' % self.ip) # 接收到的網絡數據解碼為str print(self.chan.recv(65535).decode('utf-8')) return # 這里不對可能的異常如socket.error, socket.timeout細化,直接一網打盡 except Exception as e1: if self.try_times != 0: print(u'連接%s失敗,進行重試' %self.ip) self.try_times -= 1 else: print(u'重試3次失敗,結束程序') exit(1) # 斷開連接 def close(self): self.chan.close() self.t.close() # 發送要執行的命令 def send(self, cmd): cmd += '\r' # 通過命令執行提示符來判斷命令是否執行完成 p = re.compile(r']$') result = '' # 發送要執行的命令 self.chan.send(cmd) # 回顯很長的命令可能執行較久,通過循環分批次取回回顯 sleep(2) ret = self.chan.recv(65535) ret = ret.decode('utf-8') result += ret if p.search(ret): print(result) return(result) if __name__ == '__main__': host = Linux('172.16.1.5', 'linyouyi', '123456') host.connect() host.send('ll') host.close()
原文鏈接:https://www.cnblogs.com/linyouyi/p/11474518.html
- 上一篇:iOS實現多控制器切換效果_IOS
- 下一篇:C++的運算符你真的了解嗎_C 語言
相關推薦
- 2022-11-27 C語言移除元素的三種思路講解_C 語言
- 2022-01-03 yarn版本過低導致的報錯
- 2021-12-06 樹莓派4B+EdgeX+MQTT的填坑之旅
- 2022-03-07 C語言中的rand()和rand_r()詳解_C 語言
- 2024-07-18 Spring Security之安全異常處理
- 2022-08-16 C++深入了解模板的使用_C 語言
- 2023-07-16 uniapp 微信小程序導航功能(從地址列表內點擊某一個地址)
- 2022-06-02 Kubernetes關鍵組件與結構組成介紹_云和虛擬化
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支