用Python怎么SSH到網絡設備


0. 前言

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

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

1.1 簡單測試環境

  1. 使用python3環境
  2. 使用第三方Netmiko模塊(基於Paramiko庫進行改版)
  3. 簡單的實驗環境
    在這里插入圖片描述

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混雜、眾多網絡設備,那代碼又如何去優化呢?的確,要解決一系列問題,咱們得一個一個來哈,也順便給入門的小伙伴慢慢熟悉下,后面的文章我給大家講解如何使用多進程和多線程進行優化、完整版網絡巡檢。
本人代碼功夫不深,如有缺陷望指教,多謝。


如果喜歡的我的文章,歡迎關注我的公眾號:點滴技術,掃碼關注,不定期分享
點滴技術


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM