Masstransit 是一個 .NET 免費開源的分佈式應用框架git
新建控制檯程序 mt-001,引入 Masstransit 包github
namespace mt_001 { class Program { static async Task Main(string[] args) { var bus = Bus.Factory.CreateUsingInMemory(sbc => { sbc.ReceiveEndpoint("test_queue", ep => { ep.Handler<Message>(context => Console.Out.WriteLineAsync($"Received: {context.Message.Text}")); }); }); await bus.StartAsync();// This is important ! await bus.Publish(new Message { Text = "Hi" }); Console.WriteLine("Please input your message with enter:"); string message = Console.ReadLine(); while (message != "EXIT") { await bus.Publish(new Message() {Text = message}); message = Console.ReadLine(); } await bus.StopAsync(); Console.WriteLine("Hello World!"); } } public class Message { public string Text { get; set; } } }
啓動程序,收發消息併發
新建控制檯程序 mt-002,引入 MassTransit.RabbitMQ 包框架
方法改成 CreateUsingRabbitMq,而且添加 rabbitmq hostasync
var bus = Bus.Factory.CreateUsingRabbitMq(sbc => { sbc.Host("rabbitmq://localhost"); sbc.ReceiveEndpoint("test_queue", ep => { ep.Handler<Message>(context => Console.Out.WriteLineAsync($"Received: {context.Message.Text}")); }); });
啓動兩個客戶端,消息是輪詢接收的分佈式
MassTransit 使用 C# 強類型來定義,一個消息能夠被定義爲接口,一般咱們也稱之爲消息契約單元測試
消息分爲 command 命令與 event 事件,分別對應 send 和 publish 方法測試
在不一樣項目裏面建立類來消費消息時確保命名空間一致,不然消費不到ui
命名空間:Company.Application.Contractsspa
namespace Company.Application.Contracts { using System; public interface UpdateCustomerAddress { Guid CommandId { get; } DateTime Timestamp { get; } string CustomerId { get; } string HouseNumber { get; } string Street { get; } string City { get; } string State { get; } string PostalCode { get; } } }
Command
Event
儘可能使用接口來定義消息類型,使用消息初始化器(有點困難)
使用類以及繼承時須要特別注意:
https://github.com/MINGSON666/Personal-Learning-Library/tree/main/ArchitectTrainingCamp
本做品採用知識共享署名-非商業性使用-相同方式共享 4.0 國際許可協議進行許可。
歡迎轉載、使用、從新發布,但務必保留文章署名 鄭子銘 (包含連接: http://www.cnblogs.com/MingsonZheng/ ),不得用於商業目的,基於本文修改後的做品務必以相同的許可發佈。
若有任何疑問,請與我聯繫 (MingsonZheng@outlook.com) 。