我试图了解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);
}
}
}
代码是使用网络上的示例创建的。
编辑还要添加所有名称空间是不同的项目 域 制片人 消费者
此致
月
答案 0 :(得分:7)
关于masstransit-discus的以下答案对我有帮助。
来自Google Group masstransit-discuss
... MassTransit的事情是你实际上没有发布到队列,你发布到交换机,然后设置为将该消息传递给已经订阅该交换机上的消息的其他队列。由于您没有任何消费者,因此没有人对您的消息表示任何兴趣,因此它将被忽略。
所以简单地设置一个消费者并让它听“rabbitmq:// localhost / B”。第一次运行它时,它将在它们之间创建必要的交换和链接,并且您的消息将被传递到名为B的队列。
<强>的Anders 强>
总线是所有交换,队列和服务的集合。当您在公交车上发布时,在该公交车上注册的所有消费者都将收到该公交车。
交换是实现这项工作的RabbitMQ实现。
<强>特拉维斯强>