python

关注公众号 jb51net

关闭
首页 > 脚本专栏 > python > Python网络自动化运维华为设备

Python如何实现网络自动化运维华为设备

作者:qq_2661138306

本文介绍了如何使用Python实现华为设备的网络自动化运维,包括环境配置、设备配置、功能模块实现和SFTP文件传输测试

Python网络自动化运维华为设备

本文将讲述使用Python实现华为设备的网络自动化运维。

本次运维是基于Python 3.11环境,需要提前安装paramiko和ncclient第三方库。

使用eNSP仿真模拟器来模拟真实环境的拓扑图

首先需要保证宿主机与模拟器内的网络互通

我这里使用了192.168.10.0/24的本地适配器作为桥接网卡

测试互通性效果如下:

接下来配置登录LSW4交换机设备的本地账户

int vlan 1
ip add 192.168.10.2 24    //配置VLANif 1的地址用来连接设备
user-interface vty 0 4
authentication-mode aaa    //将虚拟远程登录的模式设置为AAA认证
protocol inbound ssh        //使能SSH协议连接功能
user privilege level 15    //用户权限为15,这是最高权限
quit
stelnet server enable        //使能设备stelnet服务的功能
ssh user test                //配置SSH用户test
ssh user test service-type stelnet     //将用户的服务类型改为stelnet
ssh user test authentication-type password    //将SSH用户test的登录模式改为密码模式
aaa                                            //进入AAA视图
local-user test password cipher  Huawei@123    //配置test账户的密码
local-user test privilege level 15            //配置test账号的权限为15
local-user test service-type ssh             //配置SSH账户的权限为SSH
//以上是connect和command模块

sftp server enable                            //使能SFTP服务
ssh user test service-type  all                 //开启test全部的服务
ssh user test sftp-directory flash:            //将用户test的sftp下载目录指定为flash:下
//以上是download模块

配置LSW6的聚合链路和OSPF协议用以测试

int eth-tr 1
mode lacp
trunkport g0/0/1
trunkport g0/0/2
//配置聚合链路

int vlan 1
ip add 192.168.10.4 24
//使用该地址登录设备

ospf 
area 0
net 0.0.0.0 0.0.0.0
//与LSW4建立OSPF邻居关系

LSW4上也要进行相应OSPF和聚合链路的配置

interface Eth-Trunk1
 mode lacp-static
#
interface GigabitEthernet0/0/2
 eth-trunk 1
#
interface GigabitEthernet0/0/3
 eth-trunk 1
//聚合链路

ospf 1
 area 0.0.0.0
  network 0.0.0.0 255.255.255.255
//配置OSPF协议

接下来进行CE2设备的配置

该设备主要用来进行netconf的功能测试

int vlan 1
ip add 192.168.10.3 24
//配置登录地址

int g1/0/0
undo shut
//开启接口

stelnet server enable    //使能stelnet服务

user-interface vty 0 4
authentication-mode aaa
protocol inbound ssh
//将远程登录模式设置为AAA模式,开启SSH登录功能

aaa
 local-user netconf password cipher Huawei@123
 local-user netconf service-type ssh
 local-user netconf level 3
//创建一个netconf账户,密码为Huawei@123,服务类型为SSH,权限为3
#
ssh user netconf
ssh user netconf authentication-type password
ssh user netconf service-type snetconf
//将用户netconf的认证类型改为密码类型,服务类型改为snetconf
将
#
netconf
protocol inbound ssh port 830
//netconf的端口号为830,允许netconf通过830号端口连接
q
#
snetconf server enable
//使能snetconf服务

下载好第三方库

ncclient,paramiko

在PyCharm环境内引入对应的库

import re,time,paramiko
from datetime import datetime
from config import parameter_dict,netconf1
from ncclient import manager
from ncclient.xml_ import to_ele
from threading import Thread

创建一个类

里面定义并实现六个功能模块:

class SW:
    def __init__(self):    //初始化,建立起与设备的SSH连接。
        self.session = paramiko.SSHClient()
        self.session.set_missing_host_key_policy(paramiko.AutoAddPolicy())
        self.session.connect(hostname='192.168.10.2',password='Huawei@123',username='test',port=22,allow_agent=False,look_for_keys=False)
        self.vty = self.session.invoke_shell()
        self.command('sc 0 te')
        print('连接成功')
    def command(self,command):    //向网络设备终端输入变量并输出回显,回显字符上限为999999,类型为utf-8
        self.vty.send(command+'\n')
        time.sleep(1)
        return self.vty.recv(999999).decode('utf-8')
    def parameter_info(self):    //定义监控数据参数方法,每个5分钟输出一次设备参数
        parameter_list = []
        while True:
            for i in parameter_dict.keys():
                pat = self.command(parameter_dict[i]['command'])
                print(pat)
                res = re.compile(parameter_dict[i]['re']).findall(pat)
                print(res)
                if i == 'fan': res = res if res else "All are fans faulty"
                parameter_list.append(f'{i}:{res}')
            print('\n'.join(parameter_list))
            time.sleep(60 * 5)
    def download(self):        //通过SFTP功能下载flash:/vrpcfg.zip文件,并每隔一天保存在本地W:\\TestPython文件夹内
        while True:
            with paramiko.Transport(('192.168.10.2',22)) as t:
                t.connect(username='test',password='Huawei@123')
                sftp = paramiko.SFTPClient.from_transport(t)
                sftp.get('/vrpcfg.zip',f'W:\\TestPython\\{datetime.now().strftime("%Y_%m_%d_%H_%M_%S")}.zip')
            print('下载成功')
            time.sleep(60 * 60 * 24)
    def netconf(self,xml):        //最后配置日志文件地址为10.1.60.2
        manager.connect(host='192.168.10.3',port=22,username='netconf',password="Huawei@123",allow_agent=False,hostkey_verify=False,device_params={"name":"huawei"}).rpc(to_ele(xml))
        print("设置成功")
    def start(self):            //定义多进程模块
        Thread(target=self.download).start()
        Thread(target=self.parameter_info).start()
if __name__ == "__main__":        //满足条件则运行该文件
    for i in netconf1.values():
        SW().start()
        SW().netconf(i)

需要配置一个名为config的xml文件

内容如下所示,运行后会查看该设备的风扇状态,电源状态,CPU利用率,内存使用率,OSPF邻居状态,以及聚合链路状态。

parameter_dict = {
"fan" : {"command":"display fan","re":"Normal"},
"power" : {"command":"display power","re":"Supply|NotSupply|Sleep|No"},
"cpu" : {"command":"display cpu-usage","re":"CPU Usage            : .+?%"},
"memory" : {"command":"display memory","re":"Memory Using Percentage Is: .+?%"},
"ospf" : {"command":"display ospf peer brief","re":"down|init|2-way|exstart|exchange|loading|Full"},
"lacp" : {"command":"display eth-trunk","re":"Up|Down"}
}

netconf1 = {
    'host_log': '''
            <edit-config>
    <target>
      <running/>
    </target>
    <default-operation>merge</default-operation>
    <error-option>rollback-on-error</error-option>
    <config>
      <syslog xmlns="http://www.huawei.com/netconf/vrp" content-version="1.0" format-version="1.0">
        <syslogServers>
          <syslogServer operation="merge">
            <ipType>ipv4</ipType>
            <serverIp>10.1.60.2</serverIp>
            <isDefaultVpn>false</isDefaultVpn>
            <vrfName>_public_</vrfName>
            <timestamp>UTC</timestamp>
            <transportMode>tcp</transportMode>
          </syslogServer>
        </syslogServers>
      </syslog>
    </config>
  </edit-config>  
'''}

运行后就可以输出网络设备终端的回显内容了

以下是回显截图:

SFTP本地下载设备状态到指定路径测试

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

您可能感兴趣的文章:
阅读全文