VisitSummaryManager.java 1.26 KB
Newer Older
刘基明's avatar
刘基明 committed
1 2
package com.tanpu.community.manager;

张辰's avatar
张辰 committed
3 4
import com.alibaba.fastjson.JSON;
import com.tanpu.community.api.beans.vo.KafkaDurationUptMsg;
刘基明's avatar
刘基明 committed
5 6
import com.tanpu.community.dao.entity.community.VisitLogEntity;
import com.tanpu.community.service.VisitLogService;
张辰's avatar
张辰 committed
7 8
import com.tanpu.community.util.ConvertUtil;
import lombok.extern.slf4j.Slf4j;
刘基明's avatar
刘基明 committed
9
import org.springframework.beans.factory.annotation.Autowired;
张辰's avatar
张辰 committed
10 11
import org.springframework.kafka.annotation.KafkaListener;
import org.springframework.kafka.core.KafkaTemplate;
刘基明's avatar
刘基明 committed
12 13
import org.springframework.stereotype.Service;

张辰's avatar
张辰 committed
14
@Slf4j
刘基明's avatar
刘基明 committed
15 16 17
@Service
public class VisitSummaryManager {

张辰's avatar
张辰 committed
18 19 20 21 22 23
    private static final String kafakTopic = "tp_new_community_queue_ubr_dur_upd";

    @Autowired
    private KafkaTemplate<String, String> kafkaTemplate;

    @Autowired
刘基明's avatar
刘基明 committed
24
    private VisitLogService visitLogService;
刘基明's avatar
刘基明 committed
25

张辰's avatar
张辰 committed
26 27 28

    @KafkaListener(topics = kafakTopic)
    public void updateVisitSummary(String message) {
张辰's avatar
张辰 committed
29
        log.info("receive kafka msg: {}", message);
张辰's avatar
张辰 committed
30 31
        KafkaDurationUptMsg msg = JSON.parseObject(message, KafkaDurationUptMsg.class);
        // ident在每次进入新页面 & 回退 的时候都会随机生成一个,所以用ident做唯一key即可。
刘基明's avatar
刘基明 committed
32 33
        VisitLogEntity vs = ConvertUtil.convertFromKafka(msg);
        visitLogService.insertOrUpdateDur(vs);
张辰's avatar
张辰 committed
34
    }
刘基明's avatar
刘基明 committed
35
}