VisitSummaryManager.java 1.54 KB
package com.tanpu.community.manager;

import com.alibaba.fastjson.JSON;
import com.tanpu.biz.common.enums.clue.PageEnum;
import com.tanpu.community.api.beans.vo.KafkaDurationUptMsg;
import com.tanpu.community.dao.entity.community.VisitLogEntity;
import com.tanpu.community.service.VisitLogService;
import com.tanpu.community.util.ConvertUtil;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.kafka.annotation.KafkaListener;
import org.springframework.kafka.core.KafkaTemplate;
import org.springframework.stereotype.Service;

import java.util.Arrays;
import java.util.List;

@Slf4j
@Service
public class VisitSummaryManager {

    private static final String kafakTopic = "tp_new_community_queue_ubr_dur_upd";

    @Autowired
    private KafkaTemplate<String, String> kafkaTemplate;

    @Autowired
    private VisitLogService visitLogService;


    @KafkaListener(topics = kafakTopic)
    public void updateVisitSummary(String message) {
        // {"durMillsInc":10000,"ident":"AD7B8CE8-2DA4-4FB4-907F-C551B926BA5C","localDate":"2021-08-02","pageId":"p13503","refId":"88737580570230824","visitorId":"275321532031467520"}
//        log.info("receive kafka msg: {}", message);
        KafkaDurationUptMsg msg = JSON.parseObject(message, KafkaDurationUptMsg.class);

        // ident在每次进入新页面 & 回退 的时候都会随机生成一个,所以用ident做唯一key即可。
        VisitLogEntity vs = ConvertUtil.convertFromKafka(msg);
        visitLogService.insertOrUpdateDur(vs);
    }
}