Browse Source

update 告警生成 添加 结构物名称

dev
lucas 2 months ago
parent
commit
1dadbb0071
  1. 1
      consumers/AXY_SK/dataModel.go
  2. 21
      consumers/consumerAxySkAlarm.go

1
consumers/AXY_SK/dataModel.go

@ -16,6 +16,7 @@ type AlarmTrigger struct {
ConditionArray []int32 ConditionArray []int32
Rule int `json:"rule" db:"rule"` Rule int `json:"rule" db:"rule"`
StationIds []int StationIds []int
StructName string `json:"struct_name" db:"struct_name"`
} }
type StationAlarmTrigger struct { type StationAlarmTrigger struct {

21
consumers/consumerAxySkAlarm.go

@ -112,11 +112,17 @@ func (the *consumerAxySkAlarm) monitorInitial() error {
func (the *consumerAxySkAlarm) updateTriggerStationConfig() { func (the *consumerAxySkAlarm) updateTriggerStationConfig() {
log.Printf("--> 定时 查询pg 更新 双控配置信息") log.Printf("--> 定时 查询pg 更新 双控配置信息")
sql := `SELECT at.*,s.id as station_id,s.name as station_name sql := `SELECT
at.*,
s.id as station_id,
s.name as station_name,
ts.name as struct_name
FROM t_alarm_trigger as at FROM t_alarm_trigger as at
left join t_sensor s left join t_sensor s
on at.struct_id = s.structure on at.struct_id = s.structure
and at.factor_id = s.factor and at.factor_id = s.factor
left join t_structure ts
on at.struct_id = ts.id
order by s.id, at.alarm_level;` order by s.id, at.alarm_level;`
err := the.infoPg.Query(&the.stationAlarmTrigger, sql) err := the.infoPg.Query(&the.stationAlarmTrigger, sql)
if err != nil { if err != nil {
@ -139,6 +145,7 @@ func (the *consumerAxySkAlarm) updateTriggerStationConfig() {
ConditionArray: trigger.ConditionRaw, ConditionArray: trigger.ConditionRaw,
Rule: trigger.Rule, Rule: trigger.Rule,
StationIds: []int{trigger.StationId}, StationIds: []int{trigger.StationId},
StructName: trigger.StructName,
}) })
} else { } else {
the.configAlarmTrigger[len(the.configAlarmTrigger)-1].StationIds = the.configAlarmTrigger[len(the.configAlarmTrigger)-1].StationIds =
@ -220,7 +227,7 @@ func (the *consumerAxySkAlarm) judgeSK() string {
Time: alarmTime, Time: alarmTime,
} }
payload := the.skAlarmInfo(alarmInfoTemplate, level, detail, alarmTime, triggerTypeCodes) payload := the.skAlarmInfo(alarmInfoTemplate, level, detail, alarmTime, triggerTypeCodes, trigger.StructName)
the.OutKafka.Publish(the.Info.IoConfig.Out.Kafka.AlarmTopic, payload) the.OutKafka.Publish(the.Info.IoConfig.Out.Kafka.AlarmTopic, payload)
} else { } else {
hisK := fmt.Sprintf("%s_%s", sid, fmt.Sprintf("3077000%d", trigger.AlarmLevel)) hisK := fmt.Sprintf("%s_%s", sid, fmt.Sprintf("3077000%d", trigger.AlarmLevel))
@ -230,7 +237,7 @@ func (the *consumerAxySkAlarm) judgeSK() string {
if v, ok := the.historyStationAlarmMap[hisK]; ok { if v, ok := the.historyStationAlarmMap[hisK]; ok {
log.Printf("trigger.Id=%d, 测点[%s]本次 恢复双控%s,时刻[%s]level=%d", trigger.Id, sid, hisK, v.Time.Format("2006-01-02 15:04:05.000"), level) log.Printf("trigger.Id=%d, 测点[%s]本次 恢复双控%s,时刻[%s]level=%d", trigger.Id, sid, hisK, v.Time.Format("2006-01-02 15:04:05.000"), level)
payload := the.skAlarmElimination(alarmInfoTemplate, level, detail) payload := the.skAlarmElimination(alarmInfoTemplate, level, detail, trigger.StructName)
the.OutKafka.Publish(the.Info.IoConfig.Out.Kafka.AlarmTopic, payload) the.OutKafka.Publish(the.Info.IoConfig.Out.Kafka.AlarmTopic, payload)
delete(the.historyStationAlarmMap, hisK) delete(the.historyStationAlarmMap, hisK)
} }
@ -271,11 +278,11 @@ func (the *consumerAxySkAlarm) isHistoryAlarm(sourceId string, level int, alarmT
return isHis, hisK return isHis, hisK
} }
func (the *consumerAxySkAlarm) skAlarmInfo(alarmInfoTemplate *models.EsAlarm, level int, detail string, alarmTime time.Time, triggerTypeCodes []string) []byte { func (the *consumerAxySkAlarm) skAlarmInfo(alarmInfoTemplate *models.EsAlarm, level int, detail string, alarmTime time.Time, triggerTypeCodes []string, structName string) []byte {
alarmMsg := models.KafkaAlarm{ alarmMsg := models.KafkaAlarm{
MessageMode: "AlarmGeneration", MessageMode: "AlarmGeneration",
StructureId: alarmInfoTemplate.StructureId, StructureId: alarmInfoTemplate.StructureId,
StructureName: "", StructureName: structName,
SourceId: alarmInfoTemplate.SourceId, SourceId: alarmInfoTemplate.SourceId,
SourceName: alarmInfoTemplate.SourceName, SourceName: alarmInfoTemplate.SourceName,
AlarmTypeCode: "3077", AlarmTypeCode: "3077",
@ -290,11 +297,11 @@ func (the *consumerAxySkAlarm) skAlarmInfo(alarmInfoTemplate *models.EsAlarm, le
payload, _ := json.Marshal(alarmMsg) payload, _ := json.Marshal(alarmMsg)
return payload return payload
} }
func (the *consumerAxySkAlarm) skAlarmElimination(alarmInfoTemplate *models.EsAlarm, level int, detail string) []byte { func (the *consumerAxySkAlarm) skAlarmElimination(alarmInfoTemplate *models.EsAlarm, level int, detail string, structName string) []byte {
alarmMsg := models.KafkaAlarm{ alarmMsg := models.KafkaAlarm{
MessageMode: "AlarmAutoElimination", MessageMode: "AlarmAutoElimination",
StructureId: alarmInfoTemplate.StructureId, StructureId: alarmInfoTemplate.StructureId,
StructureName: "", StructureName: structName,
SourceId: alarmInfoTemplate.SourceId, SourceId: alarmInfoTemplate.SourceId,
SourceName: alarmInfoTemplate.SourceName, SourceName: alarmInfoTemplate.SourceName,
AlarmTypeCode: "3077", AlarmTypeCode: "3077",

Loading…
Cancel
Save