網站首頁 編程語言 正文
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
相關推薦
- 2022-10-07 react性能優化useMemo與useCallback使用對比詳解_React
- 2022-10-05 Iptables防火墻四表五鏈概念及使用技巧詳解_安全相關
- 2022-12-19 Tensorflow自定義模型與訓練超詳細講解_python
- 2022-10-12 go實現限流功能示例_Golang
- 2023-10-15 AddressSanitizer 查找內存問題
- 2022-05-24 C#?JWT權限驗證的實現_C#教程
- 2023-04-01 c++實現堆排序的示例代碼_C 語言
- 2023-12-24 npm安裝element ui出錯的問題--版本不匹配
- 最近更新
-
- 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同步修改后的遠程分支