NetCore微服务实现事务一致性masstransit之saga使用

demo如下,一个订单处理的小例子:

首先看看结果很简单:

核心代码如下:

using MassTransit;using Microsoft.Extensions.DependencyInjection;using Microsoft.Extensions.Logging;using OrderProcessor.Event;using ServiceModel;using ServiceModel.Command;using ServiceModel.DTO;using ServiceModel.Event;using System;using System.Collections.Generic;using System.Linq;using System.Text;using System.Threading.Tasks;namespace OrderProcessor.Service{    public class OrderProcessorStateMachine:MassTransitStateMachine<ProcessingOrderState>    {        private readonly ILogger<OrderProcessorStateMachine> logger;        public 天津干部培训 www.jsganxun.cn  OrderProcessorStateMachine()        {            this.logger = GlobalServiceProvider.Instance.CreateScope().ServiceProvider.GetService<ILogger<OrderProcessorStateMachine>>();            this.InstanceState(x => x.State);            this.State(() => this.Processing);            this.ConfigureCorrelationIds();            this.Initially(this.SetOrderSummitedHandler());            this.During(Processing, this.SetStockReservedHandler(), SetPaymentProcessedHandler(), SetOrderShippedHandler());            SetCompletedWhenFinalized();        }        private void ConfigureCorrelationIds()        {            this.Event(() => this.OrderSubmitted, x => x.CorrelateById(c => c.Message.CorrelationId).SelectId(c => c.Message.CorrelationId));            this.Event(() => this.StockReserved, x => x.CorrelateById(c => c.Message.CorrelationId));            this.Event(() => this.PaymentProcessed, x => x.CorrelateById(c => c.Message.CorrelationId));            this.Event(() => this.OrderShipped, x => x.CorrelateById(c => c.Message.CorrelationId));        }        private EventActivityBinder<ProcessingOrderState, IOrderSubmitted> SetOrderSummitedHandler() =>            When(OrderSubmitted).Then(c => this.UpdateSagaState(c.Instance, c.Data.Order))                                .Then(c => this.logger.LogInformation($"Order submitted to {c.Data.CorrelationId} received"))                                .ThenAsync(c => this.SendCommand<IReserveStock>("rabbitWarehouseQueue", c))                                .TransitionTo(Processing);        private EventActivityBinder<ProcessingOrderState, IStockReserved> SetStockReservedHandler() =>            When(StockReserved).Then(c => this.UpdateSagaState(c.Instance, c.Data.Order))                               .Then(c => this.logger.LogInformation($"Stock reserved to {c.Data.CorrelationId} received"))                               .ThenAsync(c => this.SendCommand<IProcessPayment>("rabbitCashierQueue", c));        private EventActivityBinder<ProcessingOrderState, IPaymentProcessed> SetPaymentProcessedHandler() =>            When(PaymentProcessed).Then(c => this.UpdateSagaState(c.Instance, c.Data.Order))                                  .Then(c => this.logger.LogInformation($"Payment processed to {c.Data.CorrelationId} received"))                                  .ThenAsync(c => this.SendCommand<IShipOrder>("rabbitDispatcherQueue", c));        private EventActivityBinder<ProcessingOrderState, IOrderShipped> SetOrderShippedHandler() =>            When(OrderShipped).Then(c =>            {                this.UpdateSagaState(c.Instance, c.Data.Order);                c.Instance.Order.Status = Status.Processed;            })                              .Publish(c => new OrderProcessed(c.Data.CorrelationId, c.Data.Order))                              .Finalize();        private void UpdateSagaState(ProcessingOrderState state, Order order)        {            var currentDate = DateTime.Now;            state.Created = currentDate;            state.Updated = currentDate;            state.Order = order;        }        private async Task SendCommand<TCommand>(string endpointKey, BehaviorContext<ProcessingOrderState, IMessage> context)            where TCommand : class, IMessage        {            var sendEndpoint = await context.GetSendEndpoint(new Uri(""));            await sendEndpoint.Send<TCommand>(new            {                CorrelationId = context.Data.CorrelationId,                Order = context.Data.Order            });        }        public  State Processing { get; private set; }        public Event<IOrderSubmitted> OrderSubmitted { get; private set; }        public Event<IOrderShipped> OrderShipped { get; set; }        public Event<IPaymentProcessed> PaymentProcessed { get; private set; }        public Event<IStockReserved> StockReserved { get; private set; }            }}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值