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