• RocketMQ源码之 事务消息的回调方法应该怎么写?


    两个回调方法:发送消息成功之后执行事务的executeLocalTransaction,回查时候调用的checkLocalTransaction。

    我的思路:执行事务的时候,调用service的方法,这个方法需要用事务注解,方法参数中传入唯一id,事务方法最后判断如果id不为空,说明此时是事务消息在调用,往事务表中插入唯一id,标志事务成功执行。而回查的时候用这个唯一id去事务表中查询。

    问题:

    1、怎样在两个回调方法中获取到这个唯一id?executeLocalTransaction的参数是message和arg,在send方法完成之后,会把send方法中为每一个message生成的唯一id赋值给transactionId,也就是说在executeLocalTransaction方法中是能获取这个id,而checkLocalTransaction方法中的参数MessageExt打印的时候会发现,message的properties中有UNIQ_KEY的值是transactionId,message自己也有transactionId属性,个人建议用properties中的属性。那么现在在checkLocalTransaction中也可以获取这个id了。如果考虑到格式一致的话,也可以用message.putUserProperty自己添加一个uuid来取代这个UNIQ_KEY。

    2、service的方法的调用可以借助sendMessageInTransaction的第二个参数,传入一个匿名内部类即可。

  • 相关阅读:
    近期用过的Linux口令备份
    使用白鹭引擎遇到的一些问题以及一些工具分享
    隐私政策
    又是一年年终总结
    初次数据整理
    skynet的timer似乎有问题
    golang .(type)语法
    mysqlbinlog输出sql
    Mysql中文字符串提取datetime
    ionic4请求skynet服务器的资源跨域问题
  • 原文地址:https://www.cnblogs.com/chuliang/p/13433471.html
Copyright © 2020-2023  润新知