使用AppHarbor和CloudAMQP在云端进行MT

时间:2012-07-10 19:52:30

标签: appharbor masstransit cloudamqp

有人成功让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指出网址中的密码

2 个答案:

答案 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协议。所以这不应该是问题;但是你能从其他地方连接到实例吗?