日本免费高清视频-国产福利视频导航-黄色在线播放国产-天天操天天操天天操天天操|www.shdianci.com

學無先后,達者為師

網站首頁 編程語言 正文

python中SSH遠程登錄設備的實現方法_python

作者:renkie人可毅 ? 更新時間: 2022-06-27 編程語言

python中支持SSH協議的模塊主要有Paramiko和netmiko兩種,本次實驗采用netmiko模塊。

netmikko模塊為python的第三方模塊,需要使用pip來下載安裝。(聯網的情況下)

下載完畢后,進入Python 3.10解釋器,如果import netmiko沒有報錯,則說明Netmiko安裝成功。

實驗拓撲

將ensp的LSW1與本地虛擬網卡loopback0進行橋接,模擬將自己的電腦橋接到以下拓撲網絡中。

實驗目的:

通過netmiko模塊的SSH逐一登錄4臺交換機LSW2-LSW5,并依次為其配置STP,默認模式為MSTP。

實驗腳本

完整代碼

from  netmiko import ConnectHandler
for i in range(20,24):
    SW={
        'device_type':'huawei',
        'ip':'10.0.1.'+str(i),
        'username':'python',
        'password':'123456',
        }
    connect=ConnectHandler(**SW)
    print('\n'+'-----------------'+'成功登錄到交換機'+SW['ip']+'-----------------')
    config_commands=['stp mode stp','dis stp | include CIST Global Info']
    output=connect.send_config_set(config_commands)
    print(output)
    connect.save_config()

1.從netmiko模塊導入它的鏈接庫函數ConnectHandler(),用于實現SSH登錄網絡設備。

from  netmiko import ConnectHandler

2.創建一個字典SW,該字典包含'device_type'、'ip'、'username'、'password'四個必選值。'device_type'用于指定設備類型,這里我們用的是華為的設備,所以'device_type'為'huawei'。

for i in range(20,24):
    SW={
        'device_type':'huawei',
        'ip':'10.0.1.'+str(i),
        'username':'python',
        'password':'123456',
        }

由于我們這里要登陸四臺設備,所以要用for循環。

3.調用ConnectHandler()函數,借用for循環,對字典SW進行SSH連接,將他賦值給變量connect,注意SW2前面的**作為標識。

connect=ConnectHandler(**SW)

在Python的在形參前加'*'和'**'表示動態形參

在形參前加'*'表示可以接受多個實參值存進數組

對于在形參前加'**'表示表示接受參數轉化為字典類型

4.如果SSH登錄成功,則提示成功登錄

  print('\n'+'-----------------'+'成功登錄到交換機'+SW['ip']+'-----------------')

5.創建一個名為config_commands的列表為參數,其元素為需要在交換機上執行的命令。

config_commands=['stp mode stp','dis stp | include CIST Global Info']

6.然后以剛剛創建的config_commands的列表為參數,調用ConnectHandler()的send_config_set()函數來使用上述命令對SW做配置,并將配置過程打印出來。

output=connect.send_config_set(config_commands)
print(output)

7.最后用save_config()保存設備配置

 connect.save_config()

實驗結果

從以上結果可知,netmiko額外替我們輸入了:system view和return。?

代碼優化

如果有大量的交換機其管理ip地址也沒什么規律性,此時直接用for循環管理ip地址來登錄設備,就不再那么靈活和使用了。此時我們可以把所有交換機的ip地址都放入都放入一個文件名為ip_list的文件,通過for循環readlines()來讀取文件中的每行ip地址,來逐臺登錄設備。

?完整腳本

from  netmiko import ConnectHandler
with open('ip_list.txt') as f:
    for line in f.readlines():
        host=line.strip()
        SW={
            'device_type':'huawei',
            'ip':host,             #host是變量,不要粗心加了引號
            'username':'python',
            'password':'123456',
            }
        connect=ConnectHandler(**SW)
        print('\n'+'-----------------'+'成功登錄到交換機'+SW['ip']+'-----------------')
        config_commands=['stp mode stp','dis stp | include CIST Global Info']
        output=connect.send_config_set(config_commands)
        print(output)
        connect.save_config()

注意:ip_list要和python腳本在一個文件夾。

結果?

原文鏈接:https://blog.csdn.net/qq_45959697/article/details/124429321

欄目分類
最近更新