有人成功让MassTransit与AppHarbor和CloudAMQP合作吗?
我正在经历一段时间。
我让发布者(网站)发送消息,但服务器(后台工作者)似乎没有发送消息。
我担心的一件事是MT需要rabbitmq方案,而CloudAMQP将方案设置为amqp。
我在配置总线时交换了方案(从amqp到rabbitmq)并注意到消息地址中的方案是rabbitmq,这是有意义的,因为我更换了它们。 但我想知道他们是否必须是服务器的amqp来接他们?
这是我发送的一条简单消息,它已经到达RabbitMQ但是服务器没有接收它。
message_id: 08cf2cbc-5b4f-14dd-1231-381f8b520000
delivery_mode: 2
headers:
Content-Type: application/vnd.masstransit+json
Payload
614 bytes
Encoding: string
{
"destinationAddress": "rabbitmq://98eabe2a-aae8-464c-8555-855518dd87d0_apphb.com:*********@lemur.cloudamqp.com/98eabe2a-aae8-464c-8555-855518dd87d0_apphb.com/Messages.Product:ProductCreatedEvent",
"headers": {},
"message": {
"id": "dd6ecfaa-60d2-4cd4-8cd6-a08a00e872fb"
},
"messageType": [
"urn:message:Messages.Product:ProductCreatedEvent"
],
"retryCount": 0,
"sourceAddress": "rabbitmq://98eabe2a-aae8-464c-8555-855518dd87d0_apphb.com:**********@lemur.cloudamqp.com/98eabe2a-aae8-464c-8555-855518dd87d0_apphb.com/enterprise_web"
}
谢谢, 乔
编辑:感谢Carl指出网址中的密码
答案 0 :(得分:7)
修改强>: 要让其他人考虑将MassTransit与CloudAMQP一起使用,您可能需要查看EasyNetQ。没有从MassTransit拿走任何东西,这是一个伟大的项目。使用像CloudAMQP这样每月收费数据的服务的问题是,MassTransit使用轮询来检查消息,而不是订阅它们(至少在我使用2.1.1的最后一个版本中)。即使您可能没有发布消息,此轮询也会影响您的数据使用。
实际上它是可能的。
快来找出,这是appharbor上背景工作者配置的全部内容。
一旦解决了问题,后台工作人员开始“活着”并消费消息。问题围绕app.config vs myworker.exe.config和config转换。一旦我意识到这是一个配置问题,这个链接帮助了。 App.config transformation for appharbor background workers
你必须换掉rabbitmq的amqp方案,但这并不坏。 这是后台工作人员的总线配置:
log.Info("Configuring MassTransit");
var rabbitUrl = ConfigurationManager.AppSettings["CLOUDAMQP_URL"];
var bus = ServiceBusFactory.New(sbc =>
{
// configure for log4net
sbc.UseLog4Net();
// configure the bus
sbc.UseRabbitMq();
sbc.UseRabbitMqRouting();
sbc.ReceiveFrom(String.Format("{0}/server", rabbitUrl.Replace("amqp://", "rabbitmq://"))); // need to swap the scheme for masstransit
// finds all the consumers in the container and register them with the bus
sbc.Subscribe(x => x.LoadFrom(container));
sbc.BeforeConsumingMessage(() =>
{
var session = container.GetInstance<ISessionFactory>().OpenSession();
CurrentSessionContext.Bind(session);
});
sbc.AfterConsumingMessage(() =>
{
var sessionFactory = container.GetInstance<ISessionFactory>();
if (CurrentSessionContext.HasBind(sessionFactory) == false) return;
var session = CurrentSessionContext.Unbind(sessionFactory);
if (session != null)
{
session.Dispose();
}
});
var results = sbc.Validate();
if (results.Any())
{
throw new Exception("MassTransit may not be setup correctly. Review validate results");
}
});
// finally inject the bus into the container
container.Inject(bus);
答案 1 :(得分:1)
我不知道邮件中有谁做过这个。祝你好运,如果你的工作正常,请向mailing list报告。
MT使用rabbitmq
的协议来确定要使用的传输。
根据RabbitMQ connector的.NET文档,它应该使用amqp
协议。所以这不应该是问题;但是你能从其他地方连接到实例吗?