java中 kafka简单应用

复制代码
1 org.springframework.kafka.core 包

2 调用地方

复制代码
@Autowired
@Qualifier("kafkaMessageServiceImpl")
private MessageService messageService;
复制代码
MessageSendLog messageSendLog = getMessageSendLog(subject, content, taskSubQuery.getTaskExeId(), info.getUserId(), taskExeName, taskConfig.getCreatorId());
messageService.commonPlatform(messageSendLog);

3 原始类

复制代码
@Slf4j
@Service("kafkaMessageServiceImpl")
@ConditionalOnExpression("!'${environment.mode}'.equals('pre')")
public class KafkaMessageServiceImpl implements MessageService {

    @Autowired
    @Qualifier("kafkaTemplateSj")
    private KafkaTemplate<String, Object> kafkaTemplateSj;
复制代码
@Override
public void platform(NotificationParam notificationParam) {
    List<AddMessageDTO> dtoList = conformityMessageDto(notificationParam);
    for (AddMessageDTO dto:dtoList) {
        notificationParam.setReceverid(dto.getReceiver());
        ItemNotificationRecord itemNotificationRecord = TaskItemTranslator.saveTaskItemNotificationRel(notificationParam);
        try {
            kafkaTemplateSj.send(MqConstant.ICWP_MSG_RECEIVE, /*dto.getMessgaeId(),*/ JSON.toJSONString(dto))
                    .addCallback(new ListenableFutureCallback<SendResult<String, Object>>() {
                        @Override
                        public void onFailure(Throwable ex) {
                            if (notificationParam.getFailCallback() != null) {
                                notificationParam.getFailCallback().accept(ex.getMessage());
                            }
                            itemNotificationRecord.setStatus("fail");
                            itemNotificationRecordMapper.insert(itemNotificationRecord);
                            log.error("platform sendKafkaMsg  log : send topic error, msg = {}", ex.getMessage(), ex);
                        }

                        @Override
                        public void onSuccess(SendResult<String, Object> result) {
                            if (notificationParam.getSuccCallback() != null) {
                                notificationParam.getSuccCallback().accept("success");
                            }
                            itemNotificationRecordMapper.insert(itemNotificationRecord);
                            log.info("platform sendKafkaMsg log : send topic success !");
                        }
                    });
        } catch (Exception e) {
            itemNotificationRecord.setStatus("fail");
            itemNotificationRecordMapper.insert(itemNotificationRecord);
            log.error("record cron sendKafkaMsgForChangeEventStatus error!", e);
        }
    }

}
复制代码
@Override
public void commonPlatform(MessageSendLog messageSendLog) {
    List<AddMessageDTO> dtoList = getByAddMessageNewDtOlist(messageSendLog);
    for (AddMessageDTO dto:dtoList) {
        MessageSendLog messageInfo = messageSendLogVo(messageSendLog,dto);
        try {
            kafkaTemplateSj.send(MqConstant.ICWP_MSG_RECEIVE, JSON.toJSONString(dto))
                    .addCallback(new ListenableFutureCallback<SendResult<String, Object>>() {
                        @Override
                        public void onFailure(Throwable ex) {
                            if (messageSendLog.getFailCallback() != null) {
                                messageSendLog.getFailCallback().accept(ex.getMessage());
                            }
                            messageInfo.setStatus("fail");
                            messageSendLogMapper.insert(messageInfo);
                            log.error("platform commonPlatKafkaMsg  log : send topic error, msg = {}", ex.getMessage(), ex);
                        }

                        @Override
                        public void onSuccess(SendResult<String, Object> result) {
                            if (messageSendLog.getSuccCallback() != null) {
                                messageSendLog.getSuccCallback().accept("success");
                            }
                            messageInfo.setStatus("success");
                            messageSendLogMapper.insert(messageInfo);
                            log.info("platform commonPlatKafkaMsg log : send topic success !");
                        }
                    });
        } catch (Exception e) {
            messageInfo.setStatus("fail");
            messageSendLogMapper.insert(messageInfo);
            log.error("record cron commonPlatKafkaMsg error!", e);
        }
    }
}
复制代码
public final static String ICWP_MSG_RECEIVE = "icwp-message-receive";
复制代码
package com.sf.gis.common.entity;

import com.baomidou.mybatisplus.annotation.*;
import io.swagger.annotations.ApiModel;
import io.swagger.annotations.ApiModelProperty;
import lombok.Getter;
import lombok.Setter;

import java.time.LocalDateTime;
import java.util.function.Consumer;

/**
 * <p>
 * 
 * </p>
 *
 * @author xxx
 * @since 2024-04-22
 */
@Getter
@Setter
@TableName("message_send_log")
@ApiModel(value = "MessageSendLog对象", description = "")
public class MessageSendLog {

    @ApiModelProperty("UUID")
    @TableId(value = "message_send_log_id", type = IdType.UUID)
    private String messageSendLogId;

    @ApiModelProperty("消息主题")
    @TableField("subject")
    private String subject;

    @ApiModelProperty("消息来源来源的业务系统(1:数字网格+、2:政法平安、3、事件分拨、 4、决策分析、5、三级工作平台)")
    @TableField("source")
    private Integer source;

    @ApiModelProperty("消息内容")
    @TableField("content")
    private String content;

    @ApiModelProperty("消息类型(0 普通、1 预警、2 待办、 3 公告) 5 领导批示 6 领导关注")
    @TableField("type")
    private Integer type;

    @ApiModelProperty("链接地址支持跳转到业务系统的详 情地址")
    @TableField("link")
    private String link;

    @ApiModelProperty("移动端链接地址")
    @TableField("mobile_link")
    private String mobileLink;

    @ApiModelProperty("消息等级(0 一般、1 紧急)")
    @TableField("priority")
    private Integer priority;

    @ApiModelProperty("发起人 ID")
    @TableField("creator")
    private String creator;

    @ApiModelProperty("接收者(根据 receiverType 来传参) 到人:用户 ID 到部门:部门 Code 到角色:角色 Code ")
    @TableField("receiver")
    private String receiver;

    @ApiModelProperty("接收者类型 0 到人、1 到部门、2 到 角色(默认 0)")
    @TableField("receiver_type")
    private Integer receiverType;

    @ApiModelProperty("业务类型code")
    @TableField("bus_code")
    private String busCode;

    @ApiModelProperty("环节状态名称")
    @TableField("link_state_name")
    private String linkStateName;

    @ApiModelProperty("消息发送状态")
    @TableField("status")
    private String status;

    @ApiModelProperty("流水号")
    @TableField("rel_id")
    private String relId;


    @TableField(value = "create_time", fill = FieldFill.INSERT)
    private LocalDateTime createTime;


    /**
     * 失败回调
     */
    @TableField(exist = false)
    private Consumer<String> failCallback;

    /**
     * 成功回调
     */
    @TableField(exist = false)
    private Consumer<String> succCallback;

}
相关推荐
C++ 老炮儿的技术栈4 分钟前
手动实现strcpy
c语言·开发语言·c++·算法·visual studio
一条叫做nemo的鱼7 分钟前
从汇编的角度揭开C++ this指针的神秘面纱(下)
java·汇编·c++·函数调用·参数传递
长勺11 分钟前
SpringMVC与Struts2对比教学
java·后端·struts
日月星辰Ace23 分钟前
Java JVM 垃圾回收器(三):现代垃圾回收器 之 ZGC
java·jvm
Joomla中文网28 分钟前
joomla5去掉后台PHP版本警告信息
开发语言·php
大磕学家ZYX35 分钟前
使用Nodejs尝试小程序后端服务编写:简单的待办事项管理demo
开发语言·javascript·小程序·node.js
先做个垃圾出来………39 分钟前
什么是装饰器?
开发语言·python
叶 落40 分钟前
[Java 基础]正则表达式
java·正则表达式·java 基础
ComputerInBook44 分钟前
理解 C++ 的 this 指针
开发语言·c++·指针·this·this指针
江城开朗的豌豆44 分钟前
Nest.js开发 VS Java开发,看看你跟适合学习那个?
java·前端·后端