华为北向网管NCE开发教程(7)历史告警采集

2024-06-15 10:28

本文主要是介绍华为北向网管NCE开发教程(7)历史告警采集,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1准备工作

准备一个FTP服务器和网管北向网络通,网管北向生成告警文件,会推送到准备的FTP服务器上。
linux,都是自带FTP的,如果是linux则无需自己搭建,如果是windows则需要自己搭建

2生成告警文件

2.1方法说明getAllHistoryAlarmsByFTP

该方法是接口EMSMgr_I中的方法

void getAllHistoryAlarmsByFTP(
java.lang.String destination, 
java.lang.String userName, 
java.lang.String password, 
mtnm.tmforum.org.globaldefs.NameAndStringValue_T[][] meNameList, 
java.lang.String[] typeList, 
java.lang.String[] excludeProbCauseList, mtnm.tmforum.org.notifications.PerceivedSeverity_T[] excludeSeverityList,
java.lang.String startTime, 
java.lang.String endTime
) throws mtnm.tmforum.org.globaldefs.ProcessingFailureException;

下面这个是华为的文档说明
在这里插入图片描述

2.2getAllHistoryAlarmsByFTP请求参数示例

Common_IHolder commonHolder = new Common_IHolder();
emsSession.getManager("EMS", commonHolder);
EMSMgr_I emsMgr = EMSMgr_IHelper.narrow(commonHolder.value);//指定生成的网元
String managedElement = "3145734"//FTP信息
//生成文件地址实际路径为192.168.1.11服务器的 /home/admin/alarms/,登录用户目录/destination中指定的目录
String destination = "192.168.1.11:alarms/"+managedElement+".txt";
String userName = "admin";
String password = "123456";//构建网元查询条件
NameAndStringValue_T[][] meNameList = new NameAndStringValue_T[1][];//网元名称列表(与typeList 条件不能同时输入)。仅支持网元/光网元,不支持EMS/SNMS。
NameAndStringValue_T[] meName = new NameAndStringValue_T[2];
meName[0] = new NameAndStringValue_T("EMS", "Huawei/NCE");
meName[1] = new NameAndStringValue_T("ManagedElement", managedElement);
meNameList[0] = meName;//网元类型和网元ID互斥,为空即可
String[] typeList = new String[0];//网元类型列表(与meNameList 条件不能同时输入)//告警原因
String[] excludeProbCauseList = new String[0];//符合此类原因的告警不查询。列表为空标识不使用该过滤条件。//告警级别
PerceivedSeverity_T[] excludeSeverityList = new PerceivedSeverity_T[0];//符合此类级别的告警不查询,列表为空标识不使用该过滤条件。//时间范围
String startTime = "20150101000000.0";//起始时间(格式如:20130111000000.0 Z 本地时间及UTC时间均支持)针对告警的清除时间进行过滤,不包括起始时间点。
String endTime = "20240604000000.0";//终止时间(格式如:20130111000000.0 Z 本地时间及UTC时间均支持)针对告警的清除时间进行过滤,包括终止时间点。//调用接口
emsMgr.getAllHistoryAlarmsByFTP(destination, userName, password, meNameList, typeList, excludeProbCauseList, excludeSeverityList, startTime, endTime);

接下来就是怎么采集了。下图所示,我先查询所有的网元,然后再根据网元的managedElement 逐个的生产历史告警。
在这里插入图片描述

2.3接收历史告警的文件传输通知

这里生成历史告警信息,不是实时的,调用方法以后,北向网管异步生成文件上传至FTP,至于最后是否成功或者失败?什么时候生成完毕?只能通过订阅通知获取。
具体的订阅通知代码,具体细节请看
华为北向网管NCE开发教程(6)消息订阅
下面是核心代码及日志记录
在这里插入图片描述

如下是记录的日志信息
在这里插入图片描述

2.4查看告警文件

登录FTP服务器(linux),在文件通知中,可以看到某个文件生成的地址信息。当然了,地址本来就是我们自己给定linux地址。下面是我们使用admin用户登录,则登录linux以后,默认路径就是在home/admin之下,然后生成的全路径也就是home/admin/alarms/xxxxx.txt

String destination = "192.168.1.11:alarms/"+managedElement+".txt";
String userName = "admin";
String password = "123456";

备注:此处建议FTP就直接用部署解析数据的程序linux服务器,这样北向网管上传的文件其实对于程序来说,就是在本地,对于你程序后续解析文件或者其他操作比较方便。不然还得单独写从FTP获取文件增加工作量。然后再很多公司的安全要求里面,FTP被当做不安全的文件传输协议,到时候开发起来,麻烦事比较多。
如果你以为万一这个服务器蹦了,考虑不考虑用集群或者负载均衡等方式,多用几台服务器来采集数据,那就别想了,这个问题无解,对接北向corba就只能单体部署。否则你就只能用rest或者kafka了。当然了用这两个,是要收钱的。

为了方便调试,我把生成在linux的文件,下载到我本地电脑上
在这里插入图片描述

3解析告警文件

其实这一块,可以不写的,毕竟解析和北向网管对接,其实没啥关系了,不过也说一下,毕竟这个确实不好弄

3.1查看文件结构

这是接口文档给的,每一列的含义,告你你用\来分割
在这里插入图片描述
这是我们打开告警文件看到的
在这里插入图片描述
将一整行拆开,可以看到,有些在标签中,有些不在标签中。
在这里插入图片描述

3.2解析思路一:XML报文

1按照行\n切割,得到一条告警信息
2按照每行的 \t分割,得到每个字段
3重新构建一个xml报文
3.1将带标签的转成标准的标签
3.2将没有标签的带上标签
4将xml报文转java对象

生成新的XML报文如下,此方法适用于,你要的数据基本都在标签中

3.2.1生成新的XLM报文

我们需要将原来的txt文件的内容变成如下这种形式

<allRoot><root><node><name>EMS</name><value>Huawei/NCE</value></node><node><name>ManagedElement</name><value>167772176</value></node><node><name>PTP</name><value>/rack=1/shelf=1/sub_shelf=0/slot=5/domain=eth/type=mac/port=1</value></node><ProposedRepairActionList_T/><oneParam><name>Location</name><value>NA</value></oneParam><oneParam><name>Direction</name><value>NA</value></oneParam><oneParam><name>MaintenanceStatus</name><value>NotInMaintenance</value></oneParam><oneParam><name>AlarmSerialNo</name><value>6833516</value></oneParam><oneParam><name>AlarmReason</name><value>缃戝彛杩炴帴涓㈠け</value></oneParam><oneParam><name>ProductName</name><value>OptiX OSN 1800 V</value></oneParam><oneParam><name>EquipmentName</name><value>B2EFS8</value></oneParam><oneParam><name>AffirmState</name><value>TRUE</value></oneParam><oneParam><name>DetailInfo</name><value/></oneParam><oneParam><name>SlaveShelf</name><value>涓诲瓙鏋?</value></oneParam><oneParam><name>HandlingSuggestion</name><value>(1)端口已使能但端口的网线或光纤没有连接好;(2)网线或光纤故障;(3)对端发送部分故障;(4)本端接收部分故障。(5)灰光光模块与彩光光模块对接,端口可能上ETH_LOS。(6)彩光光模块对接,配置不同波长。(7)对接端口的传输模式不一致或者FEC模式不一致。</value></oneParam><oneParam><name>LocationInfo</name><value>0-涓诲瓙鏋?-5-B2EFS8-1(鑷冲竷鏃ラ兘鍐呰挋璋冨害鏁版嵁缃?34M)-MAC:1</value></oneParam><oneParam><name>DeviceIP</name><value/></oneParam><oneParam><name>ROUTE_CAUSE</name><value>0</value></oneParam><oneParam><name>lResSubType</name><value>124321792</value></oneParam><alarmAffect>SA_SERVICE_AFFECTING</alarmAffect><alarmNeTime>1712600372000</alarmNeTime></root><root><node><name>EMS</name><value>Huawei/NCE</value></node><node><name>ManagedElement</name><value>167772176</value></node><node><name>EquipmentHolder</name><value>/rack=1/shelf=1/sub_shelf=0/slot=18</value></node><node><name>Equipment</name><value>1</value></node><ProposedRepairActionList_T/><oneParam><name>Location</name><value>NA</value></oneParam><oneParam><name>Direction</name><value>NA</value></oneParam><oneParam><name>MaintenanceStatus</name><value>NotInMaintenance</value></oneParam><oneParam><name>AlarmSerialNo</name><value>6835838</value></oneParam><oneParam><name>AlarmReason</name><value>鐢垫簮鏁呴殰</value></oneParam><oneParam><name>ProductName</name><value>OptiX OSN 1800 V</value></oneParam><oneParam><name>EquipmentName</name><value>F5PIU</value></oneParam><oneParam><name>AffirmState</name><value>TRUE</value></oneParam><oneParam><name>DetailInfo</name><value>48V涓荤數婧愭瑺鍘?鍛婅?﹀弬鏁癐I(16杩涘埗) 0x50</value></oneParam><oneParam><name>SlaveShelf</name><value>涓诲瓙鏋?</value></oneParam><oneParam><name>HandlingSuggestion</name><value>(1)备份电源板开关未打开;(2)电源板失效;(3)单板电源老化。</value></oneParam><oneParam><name>LocationInfo</name><value>0-涓诲瓙鏋?-18-F5PIU-OTHER</value></oneParam><oneParam><name>DeviceIP</name><value/></oneParam><oneParam><name>ROUTE_CAUSE</name><value>0</value></oneParam><oneParam><name>lResSubType</name><value>124321792</value></oneParam><alarmAffect>SA_SERVICE_AFFECTING</alarmAffect><alarmNeTime>1712616472000</alarmNeTime></root><root><node><name>EMS</name><value>Huawei/NCE</value></node><node><name>ManagedElement</name><value>167772176</value></node><node><name>PTP</name><value>/rack=1/shelf=1/sub_shelf=0/slot=5/domain=eth/type=mac/port=1</value></node><ProposedRepairActionList_T/><oneParam><name>Location</name><value>NA</value></oneParam><oneParam><name>Direction</name><value>NA</value></oneParam><oneParam><name>MaintenanceStatus</name><value>NotInMaintenance</value></oneParam><oneParam><name>AlarmSerialNo</name><value>6845135</value></oneParam><oneParam><name>AlarmReason</name><value>缃戝彛杩炴帴涓㈠け</value></oneParam><oneParam><name>ProductName</name><value>OptiX OSN 1800 V</value></oneParam><oneParam><name>EquipmentName</name><value>B2EFS8</value></oneParam><oneParam><name>AffirmState</name><value>TRUE</value></oneParam><oneParam><name>DetailInfo</name><value/></oneParam><oneParam><name>SlaveShelf</name><value>涓诲瓙鏋?</value></oneParam><oneParam><name>HandlingSuggestion</name><value>(1)端口已使能但端口的网线或光纤没有连接好;(2)网线或光纤故障;(3)对端发送部分故障;(4)本端接收部分故障。(5)灰光光模块与彩光光模块对接,端口可能上ETH_LOS。(6)彩光光模块对接,配置不同波长。(7)对接端口的传输模式不一致或者FEC模式不一致。</value></oneParam><oneParam><name>LocationInfo</name><value>0-涓诲瓙鏋?-5-B2EFS8-1(鑷冲竷鏃ラ兘鍐呰挋璋冨害鏁版嵁缃?34M)-MAC:1</value></oneParam><oneParam><name>DeviceIP</name><value/></oneParam><oneParam><name>ROUTE_CAUSE</name><value>0</value></oneParam><oneParam><name>lResSubType</name><value>124321792</value></oneParam><alarmAffect>SA_SERVICE_AFFECTING</alarmAffect><alarmNeTime>1712681968000</alarmNeTime></root>
</allRoot>

3.2.2定义新XML报文实体类

定义一个java实体类来接收上面的XML报文

@XmlRootElement(name = "allRoot")
@ToString
public class AllRoot {private List<Root> roots;@XmlElement(name = "root")public List<Root> getRoots() {return roots;}public void setRoots(List<Root> roots) {this.roots = roots;}
}@XmlRootElement(name = "root")
@ToString
public class Root {private List<Node> nodes;private List<OneParam> oneParams;private String alarmAffect;private Long alarmNeTime;public Root() {}@XmlElement(name = "node")public List<Node> getNodes() {return nodes;}public void setNodes(List<Node> nodes) {this.nodes = nodes;}@XmlElement(name = "oneParam")public List<OneParam> getOneParams() {return oneParams;}public void setOneParams(List<OneParam> oneParams) {this.oneParams = oneParams;}@XmlElement(name = "alarmAffect")public String getAlarmAffect() {return alarmAffect;}public void setAlarmAffect(String alarmAffect) {this.alarmAffect = alarmAffect;}@XmlElement(name = "alarmNeTime")public Long getAlarmNeTime() {return alarmNeTime;}public void setAlarmNeTime(Long alarmNeTime) {this.alarmNeTime = alarmNeTime;}}@XmlRootElement(name = "node")
@ToString
public class Node {private String name;private String value;@XmlElement(name = "name")public String getName() {return name;}public void setName(String name) {this.name = name;}@XmlElement(name = "value")public String getValue() {return value;}public void setValue(String value) {this.value = value;}
}@XmlRootElement(name = "oneParam")
@ToString
public class OneParam {private String name;private String value;@XmlElement(name = "name")public String getName() {return name;}public void setName(String name) {this.name = name;}@XmlElement(name = "value")public String getValue() {return value;}public void setValue(String value) {this.value = value;}
}

3.2.3代码实现

private static final Set<String> ALARM_AFFECT = new HashSet<>(Arrays.asList("SA_UNKNOWN", "SA_SERVICE_AFFECTING", "SA_NON_SERVICE_AFFECTING"));public AllRoot getAlarmDataByPath(String path) throws JAXBException {String alarmStr = JsonUtils.readStringFromSystemPath(path);String[] rows = alarmStr.split("\n");StringBuilder rootStr = new StringBuilder();rootStr.append("<allRoot>");for (int i = 1; i < rows.length; i++) {String alarmAffect = "";Long alarmNeTime = null;rootStr.append("<root>");String[] columns = rows[i].split("\t");for (int j = 1; j < columns.length; j++) {//提取标准标签内容if(columns[j].contains("<") && columns[j].contains(">")) {rootStr.append(columns[j]);//提取标签外的内容时间和ALARM_AFFECT,这里是需要特殊处理的,根据你要的业务来特殊处理,我所需要的两个字段刚好都可以满足我的需求进行特殊处理}else {if(ALARM_AFFECT.contains(columns[j])) {alarmAffect = columns[j];}else if(columns[j].contains(".0Z")){//大时间是emsTime,小时间是neTimeLong date = DateUtils.StrToLongTime(columns[j], FORMAT);if(alarmNeTime == null) {alarmNeTime = date;}else {alarmNeTime = Math.min(alarmNeTime, date);}}}}//追加标签外的alarmAffect和alarmNeTime到新报文中rootStr.append("<alarmAffect>");rootStr.append(alarmAffect);rootStr.append("</alarmAffect>");rootStr.append("<alarmNeTime>");rootStr.append(alarmNeTime.toString());rootStr.append("</alarmNeTime>");rootStr.append("</root>");}rootStr.append("</allRoot>");//新XML报文转Java对象JAXBContext jaxbContext = JAXBContext.newInstance(AllRoot.class);Unmarshaller unmarshaller = jaxbContext.createUnmarshaller();StringReader reader = new StringReader(rootStr.toString());return (AllRoot) unmarshaller.unmarshal(reader);}

3.3解析思路二:按照顺序列赋值

1按照行\n切割,得到一条告警信息
2按照每行的 \t分割,得到每个字段
3假定每行切割的第一个字段是aa属性,第二个字段是bb属性,第三个字段是cc属性

核心代码

String alarmStr = JsonUtils.readStringFromSystemPath(path);
String[] rows = alarmStr.split("\n");
String[] title = rows[0].split("\t");
StringBuilder rootStr = new StringBuilder();
for (int i = 1; i < rows.length; i++) {String[] columns = rows[i].split("\t");for (int j = 1; j < columns.length; j++) {System.out.println("第:" + j +"列");System.out.println("标题:"+title[j]);System.out.println("对应值:"+columns[j]);System.out.println("------------------");}
}

在这里插入图片描述
完毕。

这篇关于华为北向网管NCE开发教程(7)历史告警采集的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1063191

相关文章

Python pandas库自学超详细教程

《Pythonpandas库自学超详细教程》文章介绍了Pandas库的基本功能、安装方法及核心操作,涵盖数据导入(CSV/Excel等)、数据结构(Series、DataFrame)、数据清洗、转换... 目录一、什么是Pandas库(1)、Pandas 应用(2)、Pandas 功能(3)、数据结构二、安

Spring Boot集成/输出/日志级别控制/持久化开发实践

《SpringBoot集成/输出/日志级别控制/持久化开发实践》SpringBoot默认集成Logback,支持灵活日志级别配置(INFO/DEBUG等),输出包含时间戳、级别、类名等信息,并可通过... 目录一、日志概述1.1、Spring Boot日志简介1.2、日志框架与默认配置1.3、日志的核心作用

PyQt5 GUI 开发的基础知识

《PyQt5GUI开发的基础知识》Qt是一个跨平台的C++图形用户界面开发框架,支持GUI和非GUI程序开发,本文介绍了使用PyQt5进行界面开发的基础知识,包括创建简单窗口、常用控件、窗口属性设... 目录简介第一个PyQt程序最常用的三个功能模块控件QPushButton(按钮)控件QLable(纯文本

2025版mysql8.0.41 winx64 手动安装详细教程

《2025版mysql8.0.41winx64手动安装详细教程》本文指导Windows系统下MySQL安装配置,包含解压、设置环境变量、my.ini配置、初始化密码获取、服务安装与手动启动等步骤,... 目录一、下载安装包二、配置环境变量三、安装配置四、启动 mysql 服务,修改密码一、下载安装包安装地

电脑提示d3dx11_43.dll缺失怎么办? DLL文件丢失的多种修复教程

《电脑提示d3dx11_43.dll缺失怎么办?DLL文件丢失的多种修复教程》在使用电脑玩游戏或运行某些图形处理软件时,有时会遇到系统提示“d3dx11_43.dll缺失”的错误,下面我们就来分享超... 在计算机使用过程中,我们可能会遇到一些错误提示,其中之一就是缺失某个dll文件。其中,d3dx11_4

Linux下在线安装启动VNC教程

《Linux下在线安装启动VNC教程》本文指导在CentOS7上在线安装VNC,包含安装、配置密码、启动/停止、清理重启步骤及注意事项,强调需安装VNC桌面以避免黑屏,并解决端口冲突和目录权限问题... 目录描述安装VNC安装 VNC 桌面可能遇到的问题总结描js述linux中的VNC就类似于Window

Go语言编译环境设置教程

《Go语言编译环境设置教程》Go语言支持高并发(goroutine)、自动垃圾回收,编译为跨平台二进制文件,云原生兼容且社区活跃,开发便捷,内置测试与vet工具辅助检测错误,依赖模块化管理,提升开发效... 目录Go语言优势下载 Go  配置编译环境配置 GOPROXYIDE 设置(VS Code)一些基本

基于Python开发一个图像水印批量添加工具

《基于Python开发一个图像水印批量添加工具》在当今数字化内容爆炸式增长的时代,图像版权保护已成为创作者和企业的核心需求,本方案将详细介绍一个基于PythonPIL库的工业级图像水印解决方案,有需要... 目录一、系统架构设计1.1 整体处理流程1.2 类结构设计(扩展版本)二、核心算法深入解析2.1 自

Windows环境下解决Matplotlib中文字体显示问题的详细教程

《Windows环境下解决Matplotlib中文字体显示问题的详细教程》本文详细介绍了在Windows下解决Matplotlib中文显示问题的方法,包括安装字体、更新缓存、配置文件设置及编码調整,并... 目录引言问题分析解决方案详解1. 检查系统已安装字体2. 手动添加中文字体(以SimHei为例)步骤

Java JDK1.8 安装和环境配置教程详解

《JavaJDK1.8安装和环境配置教程详解》文章简要介绍了JDK1.8的安装流程,包括官网下载对应系统版本、安装时选择非系统盘路径、配置JAVA_HOME、CLASSPATH和Path环境变量,... 目录1.下载JDK2.安装JDK3.配置环境变量4.检验JDK官网下载地址:Java Downloads