.Net中简单地使用RabbitMQ消息队列

一.简介
  消息队列(Message Queue),指的是消息传递之间的容器,通常使用场景是,不需要立刻得到结果,但有需要对并发量进行控制的时候。

  有很多组件可以实现消息队列,这里使用RabbitMQ。本文是为了简单记录一下.Net (Core)中如何通过EasyNetQ去使用RabbitMQ。

二.使用

1.环境准备

  下载安装Erlang和RabbitMQ,我这里是在Windows上安装的,可以参考 《在Windows上安装RabbitMQ 指南》 。

  准备两个控制台应用(Publisher和Subscriber)和一个类库(Messages)。

  通过Nuget,给Publisher和Subscriber项目安装EasyNetQ。

   在Messages类库中,添加一个类。

public class TextMessage
{
    public string Text { get; set; }
}

2.Publisher项目

class Program
{
    public static void Main(string[] args)
    {
        var connStr = "host=127.0.0.1;virtualHost=EDCVHOST;username=admin;password=123456";

        using (var bus = RabbitHutch.CreateBus(connStr))
        {
            var input = "";
            Console.WriteLine("Please enter a message. 'Quit' to quit.");
            while ((input = Console.ReadLine()) != "Quit")
            {
                bus.PubSub.Publish(new TextMessage { Text = input });
            }
        }
    }
}

  通过EasyNetQ去连接RabbitMQ,然后使用它创建的IBus实例来发布消息。这里的通过用户在控制台输入字符串来发送消息。

3.Subscriber项目

class Program
{
    public static void Main(string[] args)
    {
        var connStr = "host=127.0.0.1;virtualHost=EDCVHOST;username=admin;password=123456";

        using (var bus = RabbitHutch.CreateBus(connStr))
        {
            bus.PubSub.Subscribe<TextMessage>("my_test_subscriptionid", HandleTextMessage);

            Console.WriteLine("Listening for messages. Hit <return> to quit.");
            Console.ReadLine();
        }
    }

    public static void HandleTextMessage(TextMessage textMessage)
    {
        Console.ForegroundColor = ConsoleColor.Red;
        Console.WriteLine("Got message: {0}", textMessage.Text);
        Console.ResetColor();
    }
}

  这里是订阅消息,只要程序在运行中,就会一直处于监听状态。只要发布者发布了指定类型的消息,这里就可以实时获取到,然后打印出来。

4.测试

   运行两个控制台应用。在Publisher中输入字符,Subscriber就会实时获取。

   进入到RabbitMQ界面查看,在connections中可以看到目前两个客户端都在运行中(running)。

   在Queues中,看到目前注册的队列只有一个。

 三.总结

  1.在.Net中可以使用EasyNetQ插件来使用RabbitMQ。

  2.本文的例子涉及到了消息队列的订阅发布模式。

  

原文地址:https://www.cnblogs.com/shadoll/p/14597682.html