Browse Source

update 添加redis 查询不到的保护处理

pull/2/head
lucas 2 months ago
parent
commit
d589c16790
  1. 33
      adaptors/安心云最新设备数据toES.go

33
adaptors/安心云最新设备数据toES.go

@ -29,6 +29,11 @@ func (the Adaptor_AXY_LastRAW) raw2es(iotaData models.IotaData) *models.EsRaw {
log.Printf("设备[%s] 数据时间 %s", iotaData.DeviceId, iotaData.TriggerTime) log.Printf("设备[%s] 数据时间 %s", iotaData.DeviceId, iotaData.TriggerTime)
deviceInfo := the.GetDeviceInfo(iotaData.DeviceId) deviceInfo := the.GetDeviceInfo(iotaData.DeviceId)
//查不到信息的数据
if deviceInfo.Name == "" {
return nil
}
dataType := "" dataType := ""
if _dataType, ok := iotaData.Data.Data["_data_type"]; ok { if _dataType, ok := iotaData.Data.Data["_data_type"]; ok {
if v, ok := _dataType.(string); ok { if v, ok := _dataType.(string); ok {
@ -61,12 +66,15 @@ func (the Adaptor_AXY_LastRAW) GetDeviceInfo(deviceId string) models.DeviceInfo
return v return v
} }
} }
v := the.GetDeviceInfoFromRedis(deviceId) v, err := the.GetDeviceInfoFromRedis(deviceId)
if err != nil {
log.Printf("设备%s 无法查询到对应信息", deviceId)
}
deviceInfoMap[deviceId] = v deviceInfoMap[deviceId] = v
return v return v
} }
func (the Adaptor_AXY_LastRAW) GetDeviceInfoFromRedis(deviceId string) models.DeviceInfo { func (the Adaptor_AXY_LastRAW) GetDeviceInfoFromRedis(deviceId string) (models.DeviceInfo, error) {
Key_Iota_device := "iota_device" Key_Iota_device := "iota_device"
key_Thing_struct := "thing_struct" key_Thing_struct := "thing_struct"
key_Iota_meta := "iota_meta" key_Iota_meta := "iota_meta"
@ -75,13 +83,23 @@ func (the Adaptor_AXY_LastRAW) GetDeviceInfoFromRedis(deviceId string) models.De
thingStruct := models.ThingStruct{} thingStruct := models.ThingStruct{}
devMeta := models.DeviceMeta{} devMeta := models.DeviceMeta{}
err1 := the.Redis.GetObj(k1, &dev) err1 := the.Redis.GetObj(k1, &dev)
if err1 != nil {
return models.DeviceInfo{RefreshTime: time.Now()}, err1
}
k2 := fmt.Sprintf("%s:%s", key_Thing_struct, dev.ThingId) k2 := fmt.Sprintf("%s:%s", key_Thing_struct, dev.ThingId)
err2 := the.Redis.GetObj(k2, &thingStruct) err2 := the.Redis.GetObj(k2, &thingStruct)
if err2 != nil {
return models.DeviceInfo{RefreshTime: time.Now()}, err2
}
k3 := fmt.Sprintf("%s:%s", key_Iota_meta, dev.DeviceMeta.Id) k3 := fmt.Sprintf("%s:%s", key_Iota_meta, dev.DeviceMeta.Id)
err3 := the.Redis.GetObj(k3, &devMeta) err3 := the.Redis.GetObj(k3, &devMeta)
if err1 != nil || err2 != nil || err3 != nil { if err3 != nil {
log.Printf("redis读取异常,err1=%s, err2=%s, err3=%s", err1, err2, err3) return models.DeviceInfo{RefreshTime: time.Now()}, err3
} }
//if err1 != nil || err2 != nil || err3 != nil {
// log.Printf("redis读取异常,err1=%s, err2=%s, err3=%s", err1, err2, err3)
// return models.DeviceInfo{}
//}
s := models.Structure{ s := models.Structure{
ThingId: thingStruct.ThingId, ThingId: thingStruct.ThingId,
@ -95,10 +113,15 @@ func (the Adaptor_AXY_LastRAW) GetDeviceInfoFromRedis(deviceId string) models.De
Structure: s, Structure: s,
DeviceMeta: devMeta, DeviceMeta: devMeta,
RefreshTime: time.Now(), RefreshTime: time.Now(),
} }, nil
} }
func toEsRaw(deviceData *models.DeviceData) *models.EsRaw { func toEsRaw(deviceData *models.DeviceData) *models.EsRaw {
if deviceData == nil {
return nil
}
dataOutMeta := deviceData.DeviceInfo.DeviceMeta.GetOutputProps() dataOutMeta := deviceData.DeviceInfo.DeviceMeta.GetOutputProps()
createNativeRaw := models.EsRaw{ createNativeRaw := models.EsRaw{
StructId: deviceData.StructId, StructId: deviceData.StructId,

Loading…
Cancel
Save