来自NServiceBus.Host的ServiceBase.RequestAdditionalTime()

时间:2013-03-11 00:56:26

标签: service timeout nservicebus startup

我们有一个NServiceBus Windows服务,在启动时需要一段时间来注册模块。我们希望从服务管理器请求额外的时间来正确启动。对于不使用NServiceBus的服务,可以使用ServiceBase.RequestAdditionalTime完成。如何使用NServiceBus.Host完成?

2 个答案:

答案 0 :(得分:1)

我们最终删除了NServiceBus.Host并改为使用Topshelf。请注意服务启动时需要的其他配置。

public static void Main(string[] args)
{
    HostFactory.Run(hf =>
    {
        hf.Service<MailboxListenerService>(svc =>
        {
            svc.ConstructUsing(mls => new MailboxListenerService());
            svc.WhenStarted((mls, control) => mls.Start(control));
            svc.WhenStopped(mls => mls.Stop());
        });
    });
}

public class MailboxListenerService
{
    private RunWebApi _webApiRunner;

    public MailboxListenerService()
    {
    }

    public bool Start(HostControl hostControl)
    {
        hostControl.RequestAdditionalTime(TimeSpan.FromSeconds(60));

        var kernel = new StandardKernel(new MailboxListenerModule());

        Configure.With()
            .DefineEndpointName("my.endpoint.name")
            .DefiningEventsAs(t => typeof(Messaging.Markers.IEvent).IsAssignableFrom(t))
            .Log4Net<NlogAppenderForLog4Net>(a => { })
            .NinjectBuilder(kernel)
            .MsmqTransport()
                .MsmqSubscriptionStorage("my.subscription.storage")
            .DisableTimeoutManager()
            .DisableSecondLevelRetries()
            .UnicastBus()
            .ImpersonateSender(false);

        _webApiRunner = kernel.Get<RunWebApi>();
        _webApiRunner.Run();

        return true;
    }

    public void Stop()
    {
        _webApiRunner.Stop();
    }
}

答案 1 :(得分:0)

不幸的是,我们在未来的版本中已经开辟了一个支持这个问题的问题

https://github.com/NServiceBus/NServiceBus/issues/1046

解决方法是使用注册表增加服务的超时时间:

http://support.microsoft.com/kb/824344