新手 - 是否需要消费者队列才能使发布在MassTransit中工作

时间:2013-03-18 19:32:54

标签: masstransit

我试图了解MassTransit和RabbitMQ并排队(第1天)

我的问题是“消费者是否有必要排队在MT工作。我问的原因是因为我首先创建了域名和生产者,但我没有在RabbitMQ管理窗口中看到任何排队的项目。”

创建消费者队列后,我可以看到消息正在排队。

根据我的理解,Producer从不了解消费者,为什么MassTransit需要消费者队列来启动消息发布?

制片人

using MassTransit;

namespace Producer
{
    class Program
    {
        static void Main(string[] args)
        {
            Bus.Initialize(sbc =>
            {
                sbc.UseRabbitMq();         //1
                sbc.UseControlBus();
                sbc.EnableMessageTracing();
                sbc.EnableRemoteIntrospection();
                sbc.ReceiveFrom("rabbitmq://localhost/MT.Producer");
                sbc.UseControlBus();
            });

            Bus.Instance.Publish(new NewOrderMessage { OrderName = "Hello World" });
        }
    }
}

申请

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using MassTransit;
using Topshelf;

namespace Consumer
{
    class Program
    {
        static void Main(string[] args)
        {
            Bus.Initialize(sbc =>
            {
                sbc.UseRabbitMq();
                sbc.UseRabbitMqRouting();
                sbc.ReceiveFrom("rabbitmq://localhost/MT.ConsumerService");
            });

            var cfg = HostFactory.New(c =>
            {
                c.SetServiceName("MT.ConsumerService");
                c.SetDisplayName("MT.ConsumerService");
                c.SetDescription("MT.ConsumerService");

                //c.BeforeStartingServices(s => {});

                c.Service<ConsumerService>(a =>
                {
                    a.ConstructUsing(service => new ConsumerService());
                    a.WhenStarted(o => o.Start());
                    a.WhenStopped(o => o.Stop());
                });

            });

            try
            {
                cfg.Run();
            }
            catch (Exception e)
            {
                Console.WriteLine(e.Message);
                throw;
            }
        }
    }
}

消息

namespace Domain
{
    public class NewOrderMessage
    {
        public NewOrderMessage()
        {
            OrderId = Guid.NewGuid();
        }
        public Guid OrderId { get; set; }
        public string OrderName { get; set; }
    }
}

消费者服务

namespace Consumer
{
    class ConsumerService
    {
        readonly IServiceBus _bus;

        public ConsumerService()
        {
            _bus = Bus.Instance;
        }

        public void Start()
        {
            _bus.SubscribeHandler<NewOrderMessage>(CreateOrder);

            Console.WriteLine("Starting....");
        }

        public void Stop()
        {    
            Console.WriteLine("Stopping....");
        }

        public void CreateOrder(NewOrderMessage command)
        {
            Console.WriteLine("Creating Order: {0}  with Id: {1}", command.OrderName, command.OrderId);
        }
    }
}

代码是使用网络上的示例创建的。

编辑还要添加所有名称空间是不同的项目 域 制片人 消费者

此致

1 个答案:

答案 0 :(得分:7)

关于masstransit-discus的以下答案对我有帮助。

来自Google Group masstransit-discuss

... MassTransit的事情是你实际上没有发布到队列,你发布到交换机,然后设置为将该消息传递给已经订阅该交换机上的消息的其他队列。由于您没有任何消费者,因此没有人对您的消息表示任何兴趣,因此它将被忽略。

所以简单地设置一个消费者并让它听“rabbitmq:// localhost / B”。第一次运行它时,它将在它们之间创建必要的交换和链接,并且您的消息将被传递到名为B的队列。

<强>的Anders

总线是所有交换,队列和服务的集合。当您在公交车上发布时,在该公交车上注册的所有消费者都将收到该公交车。

交换是实现这项工作的RabbitMQ实现。

<强>特拉维斯