seata事务集成kafka

seata事务或本地事务,完成commit后,发送kafka消息;如果事务回滚,不发送消息。

方法可以加@Transactional本地事务注解,也可以加@GlobalTransactional全局事务注解。

发送消息的类:

java 复制代码
@Service
public class MessageSendAfterCommit {
    @Autowired
    ApplicationEventPublisher eventPublisher;
    @Autowired
    private MessageQueueService messageQueueService;

    public void send(String message) {
        GlobalTransaction globalTransaction = GlobalTransactionContext.getCurrent();
        if(!isSeataTransaction()) {
            // 不是seata事务
            eventPublisher.publishEvent(message);
        } else {
            // seata事务
            MessageTransactionHook messageTransactionHook = new MessageTransactionHook(message);
            TransactionHookManager.registerHook(messageTransactionHook);
        }

    }

    private boolean isSeataTransaction() {
        return StrUtil.isNotBlank(RootContext.getXID());
    }

    class MessageTransactionHook extends TransactionHookAdapter {
        private String messageContent;
        public MessageTransactionHook(String message) {
            this.messageContent = message;
        }
        @Override
        public void afterCommit() {
            System.out.println("This is Kevin");
            // 这里发送消息。
        }
    }
}

如果是本地事务,需要发送spring事件,由监听器监听后发消息:

java 复制代码
@Component
public class TransactionEventListeners {
    @TransactionalEventListener(phase = TransactionPhase.AFTER_COMMIT)
    public void kevinTestInfoReq(String req) {
        System.out.println("kevin Zhang Transaction");
        // 发送消息。
    }
}
相关推荐
Mr.Daozhi12 小时前
RAG 进阶实战:跑通 Demo 后我连续翻了 6 次车,逐一修复才真正可用(含 Gradio Web 版)
前端·数据库·langchain·大模型·gradio·rag·科研工具
小程故事多_8012 小时前
Claude Code自定义workflow skills用法
数据库·人工智能·智能体
大鹏说大话12 小时前
SQL 排序与分组实战:解决“分组后取最新数据“
android·java·数据库
夏贰四13 小时前
数据建模工具如何筑牢数据根基?数据建模工具怎样落实标准体系?
数据库·数学建模·数据建模工具
程序猿阿伟14 小时前
《一套完整方法论:搞定图形应用的Docker镜像优化》
数据库·docker·容器
二等饼干~za89866814 小时前
geo优化源码开发搭建技术分享
大数据·网络·数据库·人工智能·音视频
数据库小学妹15 小时前
HTAP混合负载架构:如何用一个数据库同时搞定交易和分析
数据库·经验分享·架构·dba
wuxinyan12315 小时前
工业级大模型学习之路029:解决双智能体调用数据库报错问题
数据库·人工智能·python·学习·智能体
Elastic 中国社区官方博客15 小时前
Elastic 线下 Meetup 将于 2026 年 7 月 26 号下午在深圳举行
大数据·数据库·人工智能·elasticsearch·搜索引擎·ai·全文检索
YL2004042615 小时前
【Redis实战篇】秒杀实现方案(以优惠券秒杀为例)
数据库·redis