文件输出
This commit is contained in:
@@ -45,7 +45,7 @@ func (s *ReqSyncAlarmFile) Handle(request ziface.IRequest) {
|
|||||||
fmt.Println(endTime)
|
fmt.Println(endTime)
|
||||||
}
|
}
|
||||||
alarmSeq, alarmSeqOk := body.Data["alarmSeq"]
|
alarmSeq, alarmSeqOk := body.Data["alarmSeq"]
|
||||||
if !alarmSeqOk {
|
if !alarmSeqOk || alarmSeq == "" {
|
||||||
fmt.Println(alarmSeq)
|
fmt.Println(alarmSeq)
|
||||||
alarmSeq = "0"
|
alarmSeq = "0"
|
||||||
}
|
}
|
||||||
@@ -78,9 +78,13 @@ func (s *ReqSyncAlarmFile) Handle(request ziface.IRequest) {
|
|||||||
|
|
||||||
// check alarmSeq 是否存在
|
// check alarmSeq 是否存在
|
||||||
neBind, _ := parse.ConvertBindFlag(m.BindFlag)
|
neBind, _ := parse.ConvertBindFlag(m.BindFlag)
|
||||||
alarmSeqCount := service.AlarmSeqCount(neBind.NeType, neBind.NeId, int64(seq))
|
alarm, err := service.ListForSaveFile(neBind.NeType, neBind.NeId, int64(seq), startTime, endTime, syncSource)
|
||||||
if alarmSeqCount > 0 {
|
if err != nil {
|
||||||
|
zlog.Ins().ErrorF("no permissions ")
|
||||||
|
request.GetConnection().SendMsg(ReqSyncAlarmFileType, core.ResultError(ReqSyncAlarmFileName, "no permissions", reqId))
|
||||||
|
return
|
||||||
|
}
|
||||||
|
if len(alarm) > 0 {
|
||||||
request.GetConnection().SendMsg(ReqSyncAlarmFileResultType, core.Result(ReqSyncAlarmFileResultName, map[string]string{
|
request.GetConnection().SendMsg(ReqSyncAlarmFileResultType, core.Result(ReqSyncAlarmFileResultName, map[string]string{
|
||||||
"reqId": reqId,
|
"reqId": reqId,
|
||||||
"result": "succ",
|
"result": "succ",
|
||||||
|
|||||||
@@ -1,9 +1,11 @@
|
|||||||
package service
|
package service
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"errors"
|
||||||
"omc/core/db"
|
"omc/core/db"
|
||||||
"omc/core/emun"
|
"omc/core/emun"
|
||||||
"omc/handle/model"
|
"omc/handle/model"
|
||||||
|
"time"
|
||||||
|
|
||||||
"github.com/aceld/zinx/zlog"
|
"github.com/aceld/zinx/zlog"
|
||||||
)
|
)
|
||||||
@@ -11,11 +13,11 @@ import (
|
|||||||
// AlarmSeqCount alarm_seq大于等于的记录数
|
// AlarmSeqCount alarm_seq大于等于的记录数
|
||||||
func AlarmSeqCount(neType, neId string, alarmSeq int64) int64 {
|
func AlarmSeqCount(neType, neId string, alarmSeq int64) int64 {
|
||||||
var num int64
|
var num int64
|
||||||
tx := db.Client.Model(&model.Alarm{}).Where("ne_type = ? and ne_id = ?", neType, neId)
|
query := db.Client.Model(&model.Alarm{}).Where("ne_type = ? and ne_id = ?", neType, neId)
|
||||||
if alarmSeq > 0 {
|
if alarmSeq > 0 {
|
||||||
tx = tx.Where("alarm_seq >= ?", alarmSeq)
|
query = query.Where("alarm_seq >= ?", alarmSeq)
|
||||||
}
|
}
|
||||||
if err := tx.Order("alarm_seq desc").Count(&num).Error; err != nil {
|
if err := query.Order("alarm_seq desc").Count(&num).Error; err != nil {
|
||||||
zlog.Ins().ErrorF("HasAlarmSeq db error %s", err)
|
zlog.Ins().ErrorF("HasAlarmSeq db error %s", err)
|
||||||
return num
|
return num
|
||||||
}
|
}
|
||||||
@@ -85,26 +87,105 @@ func LastAlarmSeq(neType, neId string) int64 {
|
|||||||
|
|
||||||
// List 获取告警信息为文件保存
|
// List 获取告警信息为文件保存
|
||||||
func ListForSaveFile(neType, neId string, alarmSeq int64, startTime, endTime, syncSource string) ([]model.Alarm, error) {
|
func ListForSaveFile(neType, neId string, alarmSeq int64, startTime, endTime, syncSource string) ([]model.Alarm, error) {
|
||||||
|
// 基于OMC数据库的存量活动告警数据文件
|
||||||
if syncSource == "0" {
|
if syncSource == "0" {
|
||||||
|
// 取告警发生的时间,即告警本身的event_time
|
||||||
return alarmByEventTime(neType, neId, startTime, endTime)
|
return alarmByEventTime(neType, neId, startTime, endTime)
|
||||||
} else {
|
|
||||||
if alarmSeq > 0 {
|
|
||||||
return GetAlarmOfAlarmSeq(neType, neId, alarmSeq)
|
|
||||||
} else {
|
|
||||||
return GetAlarmOfLog(neType, neId, startTime, endTime)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// 从数据库读取告警记录
|
// 基于告警消息日志的告警消息流水数据文件
|
||||||
|
if syncSource == "1" {
|
||||||
|
if alarmSeq > 0 {
|
||||||
|
// 只适用于syncSource=1的情况 同步告警的起始告警消息序号
|
||||||
|
return alarmByAlarmSeq(neType, neId, alarmSeq)
|
||||||
|
} else {
|
||||||
|
// 取北向接口记录日志流水的时间
|
||||||
|
return alarmByLog(neType, neId, startTime, endTime)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return []model.Alarm{}, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
// 取告警发生的时间,即告警本身的event_time
|
||||||
|
func alarmByEventTime(neType, neId, startTime, endTime string) ([]model.Alarm, error) {
|
||||||
var alarms []model.Alarm
|
var alarms []model.Alarm
|
||||||
if err := db.Client.Model(&model.Alarm{}).Where("ne_type = ? and ne_id = ? and alarm_seq >= ?", neType, neId, alarmSeq).Order("alarm_seq asc").Find(&alarms).Error; err != nil {
|
if startTime == "" && endTime == "" {
|
||||||
zlog.Ins().ErrorF("AlarmList db error %s", err)
|
return alarms, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
query := db.Client.Model(&model.Alarm{}).Where("ne_type = ? and ne_id = ?", neType, neId)
|
||||||
|
|
||||||
|
// 从当前告警中最早的开始
|
||||||
|
if startTime != "" {
|
||||||
|
startT, err := time.Parse("2006-01-02 15:04:05", startTime)
|
||||||
|
if err != nil {
|
||||||
|
return nil, errors.New("startTime invalid")
|
||||||
|
}
|
||||||
|
query = query.Where("event_time >= ?", startT)
|
||||||
|
}
|
||||||
|
// 取到当前最新的告警截止
|
||||||
|
if endTime != "" {
|
||||||
|
endT, err := time.Parse("2006-01-02 15:04:05", endTime)
|
||||||
|
if err != nil {
|
||||||
|
return nil, errors.New("endTime invalid")
|
||||||
|
}
|
||||||
|
query = query.Where("event_time <= ?", endT)
|
||||||
|
}
|
||||||
|
|
||||||
|
// 查询
|
||||||
|
if err := query.Order("alarm_seq asc").Find(&alarms).Error; err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
return alarms, nil
|
return alarms, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func alarmByEventTime(startTime, endTime string) {
|
// 同步告警的起始告警消息序号
|
||||||
|
func alarmByAlarmSeq(neType, neId string, alarmSeq int64) ([]model.Alarm, error) {
|
||||||
|
var alarms []model.Alarm
|
||||||
|
// 查询
|
||||||
|
query := db.Client.Model(&model.Alarm{}).Where("ne_type = ? and ne_id = ? and alarm_seq >= ?", neType, neId, alarmSeq)
|
||||||
|
if err := query.Order("alarm_seq asc").Find(&alarms).Error; err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
return alarms, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
// 取北向接口记录日志流水的时间
|
||||||
|
func alarmByLog(neType, neId, startTime, endTime string) ([]model.Alarm, error) {
|
||||||
|
var alarms []model.Alarm
|
||||||
|
if startTime == "" && endTime == "" {
|
||||||
|
return alarms, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
var aIDs []int64
|
||||||
|
query := db.Client.Model(&model.NbiAlarmLog{}).Select("distinct a_id").Where("ne_type = ? and ne_id = ?", neType, neId)
|
||||||
|
|
||||||
|
// 从当前告警中最早的开始
|
||||||
|
if startTime != "" {
|
||||||
|
startT, err := time.Parse("2006-01-02 15:04:05", startTime)
|
||||||
|
if err != nil {
|
||||||
|
return nil, errors.New("startTime invalid")
|
||||||
|
}
|
||||||
|
query = query.Where("log_time >= ?", startT)
|
||||||
|
}
|
||||||
|
// 取到当前最新的告警截止
|
||||||
|
if endTime != "" {
|
||||||
|
endT, err := time.Parse("2006-01-02 15:04:05", endTime)
|
||||||
|
if err != nil {
|
||||||
|
return nil, errors.New("endTime invalid")
|
||||||
|
}
|
||||||
|
query = query.Where("log_time <= ?", endT)
|
||||||
|
}
|
||||||
|
|
||||||
|
// 查询记录日志流水的id组
|
||||||
|
if err := query.Order("alarm_seq asc").Find(&aIDs).Error; err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
// 查询告警本身的记录
|
||||||
|
if err := db.Client.Model(&model.Alarm{}).Where("id in (?)", aIDs).Find(&alarms).Error; err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
return alarms, nil
|
||||||
}
|
}
|
||||||
Reference in New Issue
Block a user