.net EasyNetQ操作RabbitMQ

Demo下載地址:https://download.csdn.net/download/u010312811/11259742

 

 

.Net下操作RabbitMQ最常用的SDK是RabbitMQ.Client和EasyNetQ,EasyNetQ操作簡單,更容易上手。

相關文章很多,但是大都是翻譯自官方的Demo,一堆的控制檯程序做消息【發佈/訂閱】顯然不是我們在生產環境所期望的,所以本文以Asp.net MVC爲例,介紹如何使用EasynetQ。

1.創建Asp.net MVC項目

項目結構如上圖所示,Services文件夾包含了消息隊列操作的相關接口,Models文件夾包含了測試需要用到的模型。

 

2.添加依賴

本文用到的組件包含:EasyNetQ、Autofac、NlLog。

添加依賴:

  • Autofac、Autofac.Mvc5
  • EasyNetQ
  • NLog

其他的依賴如:RabbitMQ.Client、Newtonsoft.Json會自動添加,不需要單獨手動添加。

 

3.消息隊列接口

3.1 IMQService

public interface IMQService
    {
        void InitMQ();

        void PublishMessage<T>(T message) where T : class;

        void SubscribeMessage();

    }

該接口中我們添加了三個接口:

  • InitMQ:初始化消息隊列
  • PublishMessage:消息發佈
  • SubscribeMessage:消息訂閱

3.2 RabbitMQService

public class RabbitMQService:IMQService
    {
        IBus bus;

        public RabbitMQService()
        {

        }
        public void InitMQ()
        {
            bus = RabbitHutch.CreateBus("host=localhost", x => x.Register<IConsumerErrorStrategy>(_ => new AlwaysRequeueErrorStrategy()));

            //訂閱消息
            SubscribeMessage();
        }

        public void PublishMessage<T>(T message)
            where T:class
        {
            bus.Publish<T>(message);
        }

        public void SubscribeMessage()
        {
            bus.SubscribeAsync<Question>("subscribe_question", x => HandleMessageAsync(x).Invoke(1));
        }

        private Func<int,Task> HandleMessageAsync(Question question)
        {
            return async (id) =>
            {
                if (new Random().Next(0, 2) == 0)
                {
                    Console.WriteLine("Exception Happened!!!!");
                    NLogHelper.Info("Exception Happened!!!!" + "   " + question.Text);
                    throw new Exception("Error Hanppened!" + "   " + question.Text);
                }
                else
                {
                    NLogHelper.Info("BEGIN");
                    Thread.Sleep(10000);
                    Console.WriteLine(string.Format("worker:{0},content:{1}", id, question.Text));
                    NLogHelper.Info(string.Format("worker:{0},content:{1}", id, question.Text));
                }
            };
        }
    }

RabbitMQService是對消息隊列接口的實現,包含了隊列的初始化、發佈、訂閱。

初始化方法僅需要在程序啓動時註冊一次

SubscribeMessage方法用於指明消息隊列的訂閱方法。本例中指明瞭對類型爲 Question 的消息使用方法 HandleMessageAsync 處理。

4.測試

 

 

參考

https://github.com/EasyNetQ/EasyNetQ/issues/734

https://github.com/EasyNetQ/EasyNetQ/issues/504

https://blog.csdn.net/chenludaniel/article/details/86138288

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章