openGauss
开源数据库
openGauss社区官网
开源社区
MogDB/openGauss 自定义snmptrapd告警信息
2022-01-06MogDB/openGauss 自定义snmptrapd告警信息
MogDB/openGauss 自定义 snmptrapd 告警信息
在实际使用中,默认的报警规则信息并不能很好的满足 snmp 服务端的需求,需要定制化报警信息,这里以添加 ip 为例,看似一个简单的将 IP 一行信息单独在报警展示出来,涉及到的配置文件修改还是挺多的。
data:image/s3,"s3://crabby-images/980e8/980e838f9f709b30e9d7cc39df4facedf4608caa" alt=""
修改 prometheus.yml 文件
首先需要修改 prometheus.yml 文件,在对应的实例下添加 ip 标签
data:image/s3,"s3://crabby-images/ff473/ff473981b6dc8680bb35e21251e7a0ace37e7da0" alt=""
修改规则报警文件
对应的报警规则文件也同样需要修改,我这里使用的是服务器磁盘使用率做报警测试,所以直接修改 node_rules.yml 文件,添加 ip 信息。
data:image/s3,"s3://crabby-images/04452/04452517a78263c8782df8e55db618ab9de8aed9" alt=""
查看 alertmanager web 界面
现在我们就可以在 alertmanager 的界面上看到我们新添加的 ip 标签了,同时报警信息里也带了 ip。
data:image/s3,"s3://crabby-images/5bfe9/5bfe930af250363ee92930285efea5bb28e77203" alt=""
修改 snmp_notifier 模版
altermanager 模块将报警消息推送到 snmp_notifier 后,还需要需改 snmp_notifier 的描述模版 description-template.tpl。
data:image/s3,"s3://crabby-images/70651/7065170bc8702235c9e820e6956e9092fa10c77d" alt=""
snmptrapd 服务器接受报警信息
data:image/s3,"s3://crabby-images/8ed12/8ed12a5afd52b1132ee28331cd6e27960a992e0b" alt=""
添加额外的模版
默认情况下,snmptrapd 只会输出三行模版信息,要添加额外的版本信息需要使用–snmp.extra-field-template 参数,比如添加第 4 行模版则在 snmp_notifier 启动时指定参数–snmp.extra-field-template=4=/opt/snmp_notifier/extra-field-template.tpl,模版 extra-field-template.tpl 可以参考 description-template.tpl 的格式
{{- if .Alerts -}}
{{- range $severity, $alerts := (groupAlertsByLabel .Alerts "severity") -}}
{{- range $index, $alert := $alerts }}
{{ $alert.Annotations.ip }}
{{ end }}
{{ end }}
{{- end -}}
启动 snmp_notifier
nohup /opt/snmp_notifier/snmp_notifier --snmp.trap-description-template=/opt/snmp_notifier/description-template.tpl --snmp.extra-field-template=4=/opt/snmp_notifier/extra-field-template.tpl > /opt/snmp_notifier/snmp_notifier.log 2>&1 &
再次查看 snmptrapd 服务器接受报警信息
data:image/s3,"s3://crabby-images/0c5dd/0c5dd71bdfb958b5c07ee43ba3bbc0cc2bc788a2" alt=""