之前有写过.net core集成使用rabbitmq的博文,见.net core使用rabbitmq消息队列,但是里面的使用很简单,而且还有几个bug,想改下,但是后来想了想,还是算了,之前使用的是.net core 2.x,还是重新整理一遍吧!
由于代码比较多,我把代码传到gitee上了,地址见:https://gitee.com/shanfeng1000/dotnetcore-demo/tree/master/Rabbitmq
这是一个Demo项目,介绍.net core集成使用rabbitmq消息队列,使用的.net core 3.1,这里简单介绍:
生产者(AspNetCore.WebApi.Producer)
在Startup的ConfigureServices方法中添加相关rabbitmq的服务:
public void ConfigureServices(IServiceCollection services) { string[] hosts = new string[] { "192.168.209.133", "192.168.209.134", "192.168.209.135" }; int port = 5672; string userName = "admin"; string password = "123456"; string virtualHost = "/"; var arguments = new Dictionary<string, object>() { { "x-queue-type", "classic" } }; #region 日志记录 services.AddLogging(builder => { builder.SetMinimumLevel(LogLevel.Trace); }); services.AddRabbitLogger(options => { options.Hosts = hosts; options.Password = password; options.Port = port; options.UserName = userName; options.VirtualHost = virtualHost; options.Arguments = arguments; options.Durable = true; options.AutoDelete = true; options.Category = "Home"; options.MinLevel = LogLevel.Trace; options.ApplicationName = "AspNetCore.WebApi.Producer"; //队列模式 options.Queue = "queue.logger"; //交换机模式 //options.Exchange = "exchange.logger"; //options.RouteQueues = new RouteQueue[] { new RouteQueue() { Queue = "queue.logger", Route = "#" } }; //options.Type = RabbitExchangeType.Topic; }); #endregion #region 普通模式 services.AddRabbitProducer("SimplePattern", options => { options.Hosts = hosts; options.Password = password; options.Port = port; options.UserName = userName; options.VirtualHost = virtualHost; options.Arguments = arguments; options.Durable = true; options.AutoDelete = true; options.InitializeCount = 3; options.Queues = new string[] { "queue.simple" }; }); #endregion #region 工作模式 services.AddRabbitProducer("WorkerPattern", options => { options.Hosts = hosts; options.Password = password; options.Port = port; options.UserName = userName; options.VirtualHost = virtualHost; options.Arguments = arguments; options.Durable = true; options.AutoDelete = true; options.InitializeCount = 3; options.Queues = new string[] { "queue.worker" }; }); #endregion #region 发布订阅模式 services.AddRabbitProducer("FanoutPattern", options => { options.Hosts = hosts; options.Password = password; options.Port = port; options.UserName = userName; options.VirtualHost = virtualHost; options.Arguments = arguments; options.Durable = true; options.AutoDelete = true; options.InitializeCount = 3; options.RouteQueues = new RouteQueue[] { new RouteQueue() { Queue = "queue.fanout1" }, new RouteQueue() { Queue = "queue.fanout2" } }; options.Type = RabbitExchangeType.Fanout; options.Exchange = "exchange.fanout"; }); #endregion #region 路由模式 services.AddRabbitProducer("DirectPattern", options => { options.Hosts = hosts; options.Password = password; options.Port = port; options.UserName = userName; options.VirtualHost = virtualHost; options.Arguments = arguments; options.Durable = true; options.AutoDelete = true; options.InitializeCount = 5; options.Exchange = "exchange.direct"; options.Type = RabbitExchangeType.Direct; options.RouteQueues = new RouteQueue[] { new RouteQueue() { Queue = "queue.direct1", Route = "direct1" }, new RouteQueue() { Queue = "queue.direct2", Route = "direct2" } }; }); #endregion #region 主题模式 services.AddRabbitProducer("TopicPattern", options => { options.Hosts = hosts; options.Password = password; options.Port = port; options.UserName = userName; options.VirtualHost = virtualHost; options.Arguments = arguments; options.Durable = true; options.AutoDelete = true; options.InitializeCount = 5; options.RouteQueues = new RouteQueue[] { new RouteQueue() { Queue = "queue.topic1", Route = "topic1.#" }, new RouteQueue() { Queue = "queue.topic2", Route = "topic2.#" } }; options.Type = RabbitExchangeType.Topic; options.Exchange = "exchange.topic"; }); #endregion ...... }