yangys
2024-03-29 153cc3fd4ef015a8b1390b2eef3d102c5859a5e7
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
package com.qianwen.smartman.modules.dmpLog.message.consumer;
 
import cn.hutool.log.StaticLog;
import com.alibaba.fastjson.JSONObject;
import java.time.Instant;
import java.time.LocalDateTime;
import java.time.ZoneId;
import java.time.format.DateTimeFormatter;
import java.util.Objects;
import org.apache.rocketmq.client.consumer.DefaultMQPushConsumer;
import org.apache.rocketmq.common.consumer.ConsumeFromWhere;
import org.apache.rocketmq.spring.annotation.RocketMQMessageListener;
import org.apache.rocketmq.spring.core.RocketMQListener;
import org.apache.rocketmq.spring.core.RocketMQPushConsumerLifecycleListener;
import com.qianwen.core.tool.utils.Func;
import com.qianwen.smartman.modules.dmpLog.constant.DmpLogSyncConstant;
import com.qianwen.smartman.modules.dmpLog.dto.DmpLogMessage;
import com.qianwen.smartman.modules.dmpLog.entity.SignalFlowLog;
import com.qianwen.smartman.modules.dmpLog.entity.SignalLog;
import com.qianwen.smartman.modules.dmpLog.entity.SignalMethodTimeLog;
import com.qianwen.smartman.modules.dmpLog.enums.LogTypeEnum;
import com.qianwen.smartman.modules.dmpLog.mapper.DmpLogSignalFlowMapper;
import com.qianwen.smartman.modules.dmpLog.mapper.DmpLogSignalMapper;
import com.qianwen.smartman.modules.dmpLog.mapper.DmpLogSignalMethodTimeMapper;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;
 
/**
 * 利用rockmq,从日志中心接受日志信息存入本地库tdengine中
 */
@RocketMQMessageListener(consumerGroup = DmpLogSyncConstant.CONSUMER_GROUP, topic = DmpLogSyncConstant.DMP_LOG_TOPIC)
@Component
public class DmpLogSyncConsumer implements RocketMQListener<DmpLogMessage>, RocketMQPushConsumerLifecycleListener {
    private DateTimeFormatter fmt = DateTimeFormatter.ofPattern("yyyyMM");
    @Autowired
    private DmpLogSignalMapper dmpLogSignalMapper;
    @Autowired
    private DmpLogSignalFlowMapper dmpLogSignalFlowMapper;
    @Autowired
    private DmpLogSignalMethodTimeMapper dmpLogSignalMethodTimeMapper;
 
    public void onMessage(DmpLogMessage dmpLogMessage) {
        JSONObject jsonObject = dmpLogMessage.getMessage();
        if (Func.isNotEmpty(jsonObject)) {
            Integer msgType = jsonObject.getInteger("Type");
            try {
                switch ((LogTypeEnum) Objects.requireNonNull(LogTypeEnum.getValue(msgType))) {
                    case Signal:
                        SignalLog signalLog = (SignalLog) jsonObject.toJavaObject(SignalLog.class);
                        signalLog.setCollectMonth(Integer.valueOf(getYearMonth(signalLog.getTimeStamp())));
                        this.dmpLogSignalMapper.save(signalLog);
                        break;
                    case Signal_Flow:
                        SignalFlowLog signalFlowLog = (SignalFlowLog) jsonObject.toJavaObject(SignalFlowLog.class);
                        signalFlowLog.setCollectMonth(Integer.valueOf(getYearMonth(signalFlowLog.getTimeStamp())));
                        this.dmpLogSignalFlowMapper.save(signalFlowLog);
                        break;
                    case HanlderInnerMethod:
                        SignalMethodTimeLog signalMethodTimeLog = (SignalMethodTimeLog) jsonObject.toJavaObject(SignalMethodTimeLog.class);
                        signalMethodTimeLog.setCollectMonth(Integer.valueOf(getYearMonth(signalMethodTimeLog.getTimeStamp())));
                        this.dmpLogSignalMethodTimeMapper.save(signalMethodTimeLog);
                        break;
                }
            } catch (Exception e) {
                StaticLog.error("存储dmplog日志异常,信息为:{}", new Object[]{e});
            }
        }
    }
 
    private int getYearMonth(Long timestamp) {
        ZoneId zone = ZoneId.systemDefault();
        LocalDateTime localDateTime = LocalDateTime.ofInstant(Instant.ofEpochMilli(timestamp.longValue()), zone);
        Integer rangeParam = Integer.valueOf(localDateTime.format(this.fmt));
        return rangeParam.intValue();
    }
 
    public void prepareStart(DefaultMQPushConsumer consumer) {
        consumer.setMaxReconsumeTimes(3);
        consumer.setConsumeFromWhere(ConsumeFromWhere.CONSUME_FROM_LAST_OFFSET);
    }
}