Python用SSH連接到網絡設備

0. 前言

自上一篇文章《用python怎麼telnet到網絡設備》,簡單使用瞭telnetlib庫給大傢演示瞭下,但是,現實環境中仍不建議去使用telnet。
SSH(Secure Shell)協議也是屬於TCP/IP協議族裡的一種,端口號22,可以代替telnet來遠程管理的一種方法。
SSH提供瞭雙向認證、數據加密等方法保證數據的安全性,推薦使用SSHv2版本

1. 測試環境及關鍵代碼解釋

1.1 簡單測試環境

  • 使用python3環境
  • 使用第三方Netmiko模塊(基於Paramiko庫進行改版)
  • 簡單的實驗環境

1.2 關鍵代碼

  • import xx:導入模塊
  • class xx:定義類
  • def xx: 定義函數
  • try-except :處理可能引發的異常
  • ssh.enable():進入enable模式
  • ssh.find_prompt():返回當前提示符
  • ssh.send_command():發送查詢命令並返回結果
  • ssh.send_config_set():發送配置命令到目標設備
  • ssh.disconnect():關閉連接

Tips: import ConnectHandler和import Netmiko是一樣的效果的哈。

2. 完整代碼

'''
歡迎關註微信公眾號:'diandijishu'
 此平臺是網路工程師個人日常技術、項目案例經驗分享,
 為鞏固及提升技術能力乃至共享所學所知技術,
 也歡迎各位工程師一起分享、一起成長。
'''

#!/usr/bin/env python
#coding:utf-8

from netmiko import ConnectHandler
from netmiko.ssh_exception import NetMikoTimeoutException
from netmiko.ssh_exception import NetMikoAuthenticationException
from datetime import datetime
import time
import logging
from my_devices import device_list as devices

'定義類'
class SSH_Client():
 '定義login_host函數,用於登陸設備'
 def login_host(self , a_device):
  try:
   self.ssh = ConnectHandler(**a_device)
   self.ssh.enable()
   reply = self.ssh.find_prompt()
   print('>' * 10 + '成功登陸結果如下:' + '>' * 10 + '\n' + reply)
   return True
  except ValueError:
   logging.warning(a_device['host'] + ' Secret 密碼錯誤')
  except NetMikoTimeoutException:
   logging.warning(a_device['host'] + ' 連接不上設備,請檢查網絡是否正常通信')
  except NetMikoAuthenticationException:
   logging.warning(a_device['host'] + ' 登陸失敗,用戶名或密碼錯誤')

 '定義do_cmd函數,用於執行命令'
 def do_cmd(self,cmds):
  '讀取文件,for語句循環執行命令'
  with open(cmds) as cmd_obj:
   for cmd in cmd_obj:
    reply = self.ssh.send_command(cmd)
    time.sleep(2)
    logging.warning('>' * 10 + cmd.rstrip() + ' 命令執行結果如下:' + '>' * 10 + '\n' + reply)
 '定義logout_host函數,關閉程序'
 def logout_host(self):
  self.ssh.disconnect()

if __name__ == '__main__':
 cmds = 'cmd.txt' # 存放執行命令文件,相對路徑
 ssh_client = SSH_Client()
 start_time = datetime.now()
 for a_device in devices:
  '如果登錄結果為True,則執行命令,然後退出'
  if ssh_client.login_host(a_device):
   ssh_client.do_cmd(cmds)
   ssh_client.logout_host()
   time.sleep(2)
 stop_time = datetime.now()
 print('總花費時長:{0}\n'.format(stop_time - start_time))

3. 運行效果

4. 報錯效果

4.1 遠程連接不上

4.2 用戶名和密碼錯誤

5. 碎碎語

結合兩篇文章,想必大傢都知道如何用python使用自帶庫或第三方庫去telnet或ssh網絡設備,然而大傢可能就會問,如果設備包含多廠商、網絡設備telnet和ssh混雜、眾多網絡設備,那代碼又如何去優化呢?的確,要解決一系列問題,咱們得一個一個來哈,也順便給入門的小夥伴慢慢熟悉下,後面的文章我給大傢講解如何使用多進程和多線程進行優化、完整版網絡巡檢。
本人代碼功夫不深,如有缺陷望指教,多謝。

以上就是Python用SSH連接到網絡設備的詳細內容,更多關於python SSH連接到網絡設備的資料請關註WalkonNet其它相關文章!

推薦閱讀: