IBM告警规则引擎语法说明
- 一、规则引擎说明
- 二、变量声明
- 三、运算符
- 四、流程控制
- 五、集合
- 六、系统函数
- 七、特殊语句
一、规则引擎说明
规则引擎是基于ANTLR 4实现的一套脚本语言,主要用于告警处理。
二、变量声明
通过表达式:变量名 = string
在规则中声明变量,其中,变量名只能为大小写字母、数字和下划线。示例:
abc = 1
$ABC = "hello"
@BCD = "world"
每条规则语句以换行符结尾。
注意:在规则处理上下文中,有三种特殊的变量,分别如下: a) 以开头,如:alarmId,此种变量为规则的输入参数,进入规则处理之前所有告警字段都会转化为
三、运算符
- 与或非运算符:&&、||、!
- 比较运算法:>、>=、<、<=、==、!=
- 计算运算符: 、-、*、/
四、流程控制
- if…else if…else…控制语句,语法定义如下:
if (...) {
...
} else if (...) {
...
} else {
...
}
- switch控制语句,语法定义如下:
switch (...) {
case "" | "":
...
break
case "":
...
default:
...
}
- foreach语句,语法定义如下:
foreach (key in $*|array|($vall,$val2,...$valn)) {
...
}
参考示例如下:
代码语言:javascript复制for (val in $*) {
log(info,"val is " val)
}
array arrTest
arrTest["abc"] = 1
arrTest["bcd"] = 2
for (val in arrTest) {
log(info,"val is " val)
}
for (val in ($1,$2,$3,$4)) {
log(info,"val is " val)
}
五、集合
- table,语法定义如下: 引用式:
table table_name = "./table_name"
default = {"", ..., ""}
直接式:
代码语言:javascript复制ta ble table_name = {
{"key", "value"},
...
{"key", "value"}
default = "default_values"
}
示例如下: 引用式:
代码语言:javascript复制table AlarmSeverity = "./Huawei/M2000/AlarmSeverity"
default = {"", ""}
==================
AlarmSeverity(tab,tab ,table):
1 Cleared
2 Minor
3 Major
4 Critical
5 Error
直接式:
代码语言:javascript复制table AlarmSeverity = {
{"1","Cleared"},
{"2","Minor"},
{"3","Major"},
{"4","Critical"},
{"5","Error"},
default = "UnKnown"
}
- array,语法定义如下:
array array_name
array_name[String|number] = [String|number]
示例如下:
代码语言:javascript复制array arrayVo
arrayVo["test"] = 1
arrayVo[2] = "1001"
arrayVo[$a] = $b
log(info,"arrayVo["test"]=" arrayVo["test"])
log(info,"arrayVo["2"]=" arrayVo["2"])
log(info,"arrayVo["$a"]=" arrayVo["$a"])
六、系统函数
注意:所有带参数的函数,使用时每个参数之间不能存在空格。
- getdate,返回当前时间毫秒数,用法如下:
$currentTime = getdate
log(info, "Current millisecond = " $currentTime) # 1469689875121, JavaSystem.currentTimeMillis()
- match,精确匹配字符串,返回true或false,用法如下:
if (match($AlarmName, "LinkDown")) {
log(info, "It's matched")
} else {
log(info, "It's not matched")
}
- rematch,模糊匹配,基于Java的正则表达式实现,返回true或false,用法如下:
if (rematch($AlarmName, ".*LinkDown.*")) {
log(info, "It's matched")
} else {
log(info, "It's not matched")
}
- extract,截取字符串中匹配的数据,基于Java正则表达式的group实现,返回匹配到的字符串,用法如下:
$AlertKey = "Node=123,alarmname=linkdown"
$Node = extract($AlertKey,".*Node=([0-9*],.*)")
log(info,"$Node=" $Node) #123
- exits,判断某个变量是否存在,返回true或false,用法如下:
if (exist($AlarmName)) {
log(info, "It's exists")
} else {
log(info, "It's not exists")
}
- DateToTime,将制定日志转化为毫秒级,时区以探针运行时区为准,返回毫秒数,用法如下:
$NV_EVENT_TIME = "2020-05-18 10:52:00"
$EventTime = DateToTime($NV_EVENT_TIME,"yyyy-MM-dd HH:mm:ss")
这里的DateTime的第二个参数的格式参考Java语言提供的SimpleDateFormat类格式。
- int,将数字字符串转换为int数值,若不可转化则会出现异常,返回int数值,用法如下:
$val = int("1111")
- ltrim,去掉字符串的左边空格,返回处理后的字符串,用法如下:
$node = ltrim($node)
- rtrim,去掉字符串的右边空格,返回处理后的字符串,用法如下:
$node = rtrim($node)
- lookup,根据指定Key获取其对应的1个或多个字段的value,lookup(key, table_name),用法如下:
$Severity = lookup($Severity,AlarmServerity)
[@SiteCode, @SiteName, @SitePriority, @Location, @ZoneTime, @SiteType, @collocation_name, @collocation_Id, @power_type, @LocalNodeAlias $#124;||] = lookup(@Node, deviceSite3G4G)
- log,打印日志,格式:log(level, “”),其中level取值为debug,info,warn,error。
- setContextVar,设置环境变量到规则引擎的环境变量中去,例如可以在core.properties里面定义一个探针运行时的环境变量。
@ccc=setContextVar("xxxxName")
@ddd=$xxxxName
xxxxNamexxxxName
@ccc=setContextVar("xxxxName","abcd")
@ddd=$abcd
abcd
@ccc=setContextVar("xxxxName","abcd")@ddd=$abcd
abcd
- TimeFromIBMTime,将IBM的时间格式转换为UTC的时间,用法如下:
@mv36AlarmRaisingTimeTest = TimeFromIBMTime($mv36AlarmRaisingTimeTest)
- hostname,获取执行机器的主机名。
- lower,将字符串转换为小写字母。
lower("ABcD")
- substr,截取字符串。
substr("ssss",1,2)
- clear,清空规则引擎中的环境变量,包括输入输出和一些中间变量。
- getenv,获取执行环境的环境变量的值,相当于Java中调用System.getProperty()。
getenv("Probe_Name")
- getpid,获取执行进程的PID。
- getplatform,获取运行平台名称。
- recover,将设置的discard标示清空。
- remove,移除变量的定义。
remove("passwd")
- update,更新事件。
- updateload,触发更新事件。
- upper,将字符串转换为大写字母。
upper("abcD")
- hashCode,输出字符串的hashCode码,输出为格式化后的20位hashCode,前十位为String的hashCode,后十位为字符串倒序的hashCode码。
@alarmId=hashCode($alarmID)
七、特殊语句
- discard,丢弃次规则处理的结果,一般用于丢弃告警的场景,如告警风暴发生时,丢弃低优先级的告警,用法如下:
if(int($AlarmStomFlg) == 1 && int($Severity) <= 2) { # ,2
discard
}
- include,引用其他规则文件或lookup文件,支持classpath路径、相对路径和绝对路径三种引用方式,用法如下:
include "classpath:config/abc.rules" # classpath
include "./rules/test.rules" # (config),
include '/opt/ict/collector/instance/Probe-0010/config/lookup/Device.lookup" #