在连接总线时断开消费者的连接

时间:2018-03-05 19:45:05

标签: masstransit

我们有以下用例:

我们有两条公共汽车(内部和外部)。我们的想法是我们自己的服务使用内部总线,所有第三方服务都使用外部总线。我们创建了一个充当消息路由器的服务(恰当地命名为MessageRouter)。

当消息在内部总线上发布时,MessageRouter可以接收该消息并将其放在外部总线上,反之亦然。通过配置,我们可以判断允许哪些消息从外部传递到外部到内部。这本身就可以了。

我们已将消息分组,我们有事件,命令和请求。每个服务都有三个ReceiveEnpoints,每个消息类型一个。这意味着所有事件都在事件队列等排队。服务'订阅的每条消息都包含在内。得到它自己的消费者。

var queues = new Dictionary<string, IEnumerable<Type>>
{
    // ReSharper disable once PossibleMultipleEnumeration
    { "Events", consumerTypes.Where(ct => ct.GetGenericArguments().Any(ga => typeof(IEvent).IsAssignableFrom(ga))) },
    // ReSharper disable once PossibleMultipleEnumeration
    { "Commands", consumerTypes.Where(ct => ct.GetGenericArguments().Any(ga => typeof(ICommand).IsAssignableFrom(ga))) },
    // ReSharper disable once PossibleMultipleEnumeration
    { "Queries", consumerTypes.Where(ct => ct.GetGenericArguments().Any(ga => typeof(IQuery).IsAssignableFrom(ga))) }
};

foreach (var queue in queues)
{
    config.ReceiveEndpoint(GetConsumerQueueName(queue.Key), cfg =>
    {
        foreach (var consumerType in queue.Value)
        {
            cfg.Consumer(consumerType, consumerContainer.Resolve);
        }
        configurator?.Invoke((T)cfg);
    });
}

configIBusFactoryConfigurator的位置。该代码在服务启动时调用。

我们希望在MessageRouter中能够做到的是动态地&#39;添加,更重要的是,从ReceiveEndpoint中删除消费者。

到目前为止,我们还没有运气。我们尝试通过在ConnectConsumer实例上使用BusControl方法添加Consumer。这为我们提供了ConnectHandle,其Disconnect方法。但是,使用此方法时,我们的消费者不会收集消息。看看手柄向我们展示它是MultipleConnectHandle,但是,手柄没有内部&#39;处理

有没有办法使用Consumer方法注册不同的消费者并获取他们的ConnectHandle,以便我们可以在需要时Disconnect消费者?

如上所述,理想情况下,我们希望能够动态添加和删除使用者到ReceiveEndpoint。

1 个答案:

答案 0 :(得分:0)

在总线启动时,您无法在接收端点上添加/删除使用者,不支持任何方式,形状或形式。

但是,您可以在单独的队列中将新的接收端点与一个或多个使用者连接。在上面的例子中,您似乎没有在连接接收端点之前注册您的消费者,这就是您在句柄集合中没有看到任何内容的原因。