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");
        // 发送消息。
    }
}
相关推荐
倔强的石头_4 小时前
kingbase备份与恢复实战(二)—— sys_dump库级逻辑备份与恢复(Windows详细步骤)
数据库
jiayou641 天前
KingbaseES 实战:深度解析数据库对象访问权限管理
数据库
李广坤2 天前
MySQL 大表字段变更实践(改名 + 改类型 + 改长度)
数据库
DemonAvenger3 天前
Kafka性能调优:从参数配置到硬件选择的全方位指南
性能优化·kafka·消息队列
初次攀爬者3 天前
ZooKeeper 实现分布式锁的两种方式
分布式·后端·zookeeper
爱可生开源社区3 天前
2026 年,优秀的 DBA 需要具备哪些素质?
数据库·人工智能·dba
随逸1773 天前
《从零搭建NestJS项目》
数据库·typescript
加号34 天前
windows系统下mysql多源数据库同步部署
数据库·windows·mysql
シ風箏4 天前
MySQL【部署 04】Docker部署 MySQL8.0.32 版本(网盘镜像及启动命令分享)
数据库·mysql·docker
李慕婉学姐4 天前
Springboot智慧社区系统设计与开发6n99s526(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·spring boot·后端