博客
关于我
Azure Messaging-ServiceBus Messaging消息队列技术系列7-消息事务
阅读量:460 次
发布时间:2019-03-06

本文共 2232 字,大约阅读时间需要 7 分钟。

上篇博文中我们介绍了Azure Messaging-ServiceBus Messaging消息回执机制。

本文中我们主要研究消息的事务。直奔主题:

  • Service Bus Queues支持事务,基于TransactionScope
  • Service Bus Queues provide support for local transactions in the context of a single queue.
  • 事务的限制:事务只能包含一个Queue或者Topic,订阅不能放在事务中,同时事务不支持其他系统,例如数据库

那消息事务的实际应用场景有哪些呢?例如:

1.启动一个事务性的会话,将发送更新订单状态消息和更新账户余额消息放到一个事务中,消息发送失败后 rollback,确认消息未被发送。

2.发送更新订单状态消息和更新账户余额消息成功后,启动一个事务性的会话,接收并处理这两条消息。

那我们先从同一个队列中发送多条消息这个场景验证:

1   public static void SendMessageTransactional() 2         { 3             var sbUtils = new ServiceBusUtils(); 4  5             //创建队列 6             sbUtils.CreateQueue(queueName, false); 7  8             //多次发送消息到OrderQueue 9             var queueSendClient = sbUtils.GetQueueClient(queueName);10 11             using (var trans = new TransactionScope())12             {13                 var order1 = CreateSalesOrder(1);14                 var order2 = CreateSalesOrder(2);15                 var message1 = sbUtils.Create(order1);16                 var message2 = sbUtils.Create(order2);17                 queueSendClient.Send(message1);18                 queueSendClient.Send(message2);19                 Console.WriteLine("Send but uncomplete!");20                 trans.Complete();21 22                 Console.WriteLine("Complete!");23             }            24         }

发送消息完成,但是未提交事务前,队列是这样的:

事务提交后Complete:

然后,我们继续研究验证同一个队列接收消息的事务性:有个前提要求:

消息接收时,如果启动事务,消息消费接收模式必须是PeekAndLock模式。

消息接收完成,如果事务不Complete,消息仍旧在消息队列中。

1 public static void ReceiveMessageTransactional() 2         { 3             var sbUtils = new ServiceBusUtils(); 4             var queueReveiveClient = sbUtils.GetReceiveQueueClient(queueName, ReceiveMode.PeekLock); 5             using (var trans = new TransactionScope()) 6             { 7                 var message1 = queueReveiveClient.Receive(); 8                 message1.Complete(); 9                 var message2 = queueReveiveClient.Receive();10                 message2.Complete();11                 Console.WriteLine("Received but uncomplete!");12                 trans.Complete();13 14                 Console.WriteLine("Complete!");15             }16         }

当接收完消息,事务未提交时:

队列中的消息是:

事务提交后:

Azure Service Bus 中消息:

消息已经被消费。

以上就是Azure ServiceBus 中对消息事务的支持。

 

2017/3/30

转载地址:http://qhhfz.baihongyu.com/

你可能感兴趣的文章
MySQL 多表联合查询:UNION 和 JOIN 分析
查看>>
MySQL 大数据量快速插入方法和语句优化
查看>>
mysql 如何给SQL添加索引
查看>>
mysql 字段区分大小写
查看>>
mysql 字段合并问题(group_concat)
查看>>
mysql 字段类型类型
查看>>
MySQL 字符串截取函数,字段截取,字符串截取
查看>>
MySQL 存储引擎
查看>>
mysql 存储过程 注入_mysql 视图 事务 存储过程 SQL注入
查看>>
MySQL 存储过程参数:in、out、inout
查看>>
mysql 存储过程每隔一段时间执行一次
查看>>
mysql 存在update不存在insert
查看>>
Mysql 学习总结(86)—— Mysql 的 JSON 数据类型正确使用姿势
查看>>
Mysql 学习总结(87)—— Mysql 执行计划(Explain)再总结
查看>>
Mysql 学习总结(88)—— Mysql 官方为什么不推荐用雪花 id 和 uuid 做 MySQL 主键
查看>>
Mysql 学习总结(89)—— Mysql 库表容量统计
查看>>
mysql 实现主从复制/主从同步
查看>>
mysql 审核_审核MySQL数据库上的登录
查看>>
mysql 导入 sql 文件时 ERROR 1046 (3D000) no database selected 错误的解决
查看>>
mysql 导入导出大文件
查看>>