.NET 雲原生架構師訓練營(模塊二 基礎鞏固 RabbitMQ Masstransit 介紹)--學習筆記

2.6.6 RabbitMQ -- Masstransit 介紹

  • Masstransit 是什麼
  • Quickstart
  • 消息 Message

Masstransit 是什麼

Masstransit 是一個 .NET 免費開源的分佈式應用框架git

  • 集成多種消息中間件(Rabbitmq, Azure, Service Bus, ActiveMQ, Kafka, In-Memory)
  • 強大且完整的消息模式(發佈與訂閱,saga,event-driven state machine,最終一致性支持)
  • 端到端解決方案(消息路由,異常,重試,併發控制,鏈接與消費生命週期管理)
  • 使用簡單
  • 單元測試友好
  • 內置監控

Quickstart

新建控制檯程序 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}"));
    });
});

啓動兩個客戶端,消息是輪詢接收的分佈式

消息 Message

  • 消息
  • 消息類型
  • 消息頭
  • 最佳實踐

消息

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

  • 經過 send 發送到一個 endpoint

Event

  • 經過 publish,不直接發送到 endpoint,發佈到多個消費者
  • 一般以名稱短語(過去式的形式來命名)好比 OrderCreatedEvent, OrderSubmitted, OrderPaid, OrderDeliveried

消息頭

最佳實踐

儘可能使用接口來定義消息類型,使用消息初始化器(有點困難)

使用類以及繼承時須要特別注意:

  • 經過消費基類並利用多態行爲來處理,總會遇到不少問題
  • 消息格式設計不是面向對象設計,消息中應該只包含狀態而不該該包含行爲
  • 大的基類也會產生不少問題,特別是在支持消息版本的時候

GitHub源碼連接:

https://github.com/MINGSON666/Personal-Learning-Library/tree/main/ArchitectTrainingCamp

知識共享許可協議

本做品採用知識共享署名-非商業性使用-相同方式共享 4.0 國際許可協議進行許可。

歡迎轉載、使用、從新發布,但務必保留文章署名 鄭子銘 (包含連接: http://www.cnblogs.com/MingsonZheng/ ),不得用於商業目的,基於本文修改後的做品務必以相同的許可發佈。

若有任何疑問,請與我聯繫 (MingsonZheng@outlook.com) 。

相關文章
相關標籤/搜索