当前位置: 首页 > news >正文

四网合一的网站被窝家装公司

四网合一的网站,被窝家装公司,微格式wordpress,软文推广代理事务消息介绍 在一些对数据一致性有强需求的场景#xff0c;可以用 Apache RocketMQ 事务消息来解决#xff0c;从而保证上下游数据的一致性。 以电商交易场景为例#xff0c;用户支付订单这一核心操作的同时会涉及到下游物流发货、积分变更、购物车状态清空等多个子系统的…事务消息介绍 在一些对数据一致性有强需求的场景可以用 Apache RocketMQ 事务消息来解决从而保证上下游数据的一致性。 以电商交易场景为例用户支付订单这一核心操作的同时会涉及到下游物流发货、积分变更、购物车状态清空等多个子系统的变更。当前业务的处理分支包括 主分支订单系统状态更新由未支付变更为支付成功。物流系统状态新增新增待发货物流记录创建订单物流记录。积分系统状态变更变更用户积分更新用户积分表。购物车系统状态变更清空购物车更新用户购物车记录。 当主分支订单系统状态更新失败后物流、积分、购物车系统都不应该接收到消息 事务消息的发送流程 使用普通消息是做不到的因为他会直接将消息发送到topic中 而事务消息参考了两阶段提交的原理 先把消息发送broker中当消息发送成功后会执行本地事务通过本地事务的执行情况返回一个状态状态对应三种情况 LocalTransactionState.UNKNOW需要broker调用发送端的回查机制LocalTransactionState.COMMIT_MESSAGEbroker将消息发送到指定的topic此时消费端可以接收到消息LocalTransactionState.ROLLBACK_MESSAGEbroker丢弃消息不发送到指定的topic消费端接收不到消息 整个事务消息的详细交互流程如下图所示 Test public void sendTrans() throws MQBrokerException, RemotingException, InterruptedException, MQClientException {// 创建事务消息发送客户端TransactionMQProducer transProducer new TransactionMQProducer(test-trans-producer);transProducer.setNamesrvAddr(RocketMQConfig.NAME_SERVER_ADDR);// 指定回查事务消息时的线程池ExecutorService executorService new ThreadPoolExecutor(2, 5, 100, TimeUnit.SECONDS, new ArrayBlockingQueue(2000), new ThreadFactory() {Overridepublic Thread newThread(Runnable r) {Thread thread new Thread(r);thread.setName(client-transaction-msg-check-thread);return thread;}});transProducer.setExecutorService(executorService);// 设置事务监听器transProducer.setTransactionListener(new TransactionListener() {// 执行本地事务Overridepublic LocalTransactionState executeLocalTransaction(Message message, Object o) {System.out.println(Thread.currentThread().getName() 执行本地事务);// 触发回查机制return LocalTransactionState.UNKNOW;}// 回查本地事务如果执行本地事务返回UNKNOW状态或者生产者应用退出导致本地事务未提交任何状态Overridepublic LocalTransactionState checkLocalTransaction(MessageExt messageExt) {System.out.println(Thread.currentThread().getName() 触发事务回查);// 提交事务return LocalTransactionState.COMMIT_MESSAGE;}});transProducer.start();Message message new Message(RocketMQConfig.TEST_TOPIC, hello world.getBytes());// 发送事务消息SendResult send transProducer.sendMessageInTransaction(message,null);System.out.println(send.getSendStatus());Thread.sleep(Integer.MAX_VALUE); }注需要注意的是事务消息的生产组名称 ProducerGroupName不能随意设置。事务消息有回查机制回查时Broker端如果发现原始生产者已经崩溃则会联系同一生产者组的其他生产者实例回查本地事务执行情况以Commit或Rollback半事务消息。
http://www.dnsts.com.cn/news/180539.html

相关文章:

  • 淮安做网站app大连网站开发选领超科技
  • 常州市武进区城乡建设局网站国外服务器域名需要备案吗
  • php 网站开发流程图dede转wordpress
  • 东营专业网站建设公司排行图书类网站开发的背景
  • seo是什么意思职业seo网站优化代码
  • 网站代码如何做优化平面设计师工资多少钱一个月
  • 宁波市政务网站建设和管理标准基于php+mysql的网站开发
  • 两学一做网站进不去网站设计 案例
  • 现在外贸做哪个网站好google国际版入口
  • 建设项目公示网站论述电子商务网站建设的流程
  • 网站建设公司广告语 宣传语自己做头像的网站非流光
  • 长沙网站制造个人网站建设思路
  • 太原网站制作可以做烟的网站吗
  • 成品ppt的网站免费直播有哪些公司网站被百度转码了
  • 济南网站建设百家号中国企业排名500强
  • 做企业网站合同如何用网站开发工具停止网页进程
  • 湖南环保设备公司中企动力网站建设技术支持企业网站设计与规划论文
  • wordpress 英文站什么叫网站app
  • wordpress 中文插件大全长沙百度seo代理
  • 做ppt赚钱的网站四川省建设厅职改办网站
  • 怎么做网站账号注册机大连市场所码二维码图片
  • tklink的登录做网站做众筹的网站
  • 湖北建设网站四库一平台搭建视频网站
  • 魔方网站导航设计怎么让谷歌收录我的网站
  • 网站建设应解决的问题网页设计的五大原则
  • 深圳网站建设_请到中投网络网站建设 amp 找VX cp5173
  • 深圳网站建设小江泰安房产网签查询系统
  • 网站的ftp网站设计与建设代码
  • 游戏网页版在线玩入口南宁企业网站排名优化
  • 手机当服务器建网站企业网站建设方案市场