NullReferenceException beim Initialisieren von NServiceBus in der Webanwendung Application_Start-Methode

Ich führe die 2.0 RTM von NServiceBus aus und erhalte eine NullReferenceException, wenn mein MessageModule den CurrentSessionContext an meine NHibernate-SessionFactory bindet.

In meinem Application_Start rufe ich die folgende Methode auf:

public static void WithWeb(IUnityContainer container)
{
    log4net.Config.XmlConfigurator.Configure();

    var childContainer = container.CreateChildContainer();

    childContainer.RegisterInstance<ISessionFactory>(NHibernateSession.SessionFactory);

    var bus = NServiceBus.Configure.WithWeb()
        .UnityBuilder(childContainer)
        .Log4Net()
        .XmlSerializer()
        .MsmqTransport()
        .IsTransactional(true)
        .PurgeOnStartup(false)
        .UnicastBus()
        .ImpersonateSender(false)
        .LoadMessageHandlers()
        .CreateBus();

    var activeBus = bus.Start();

    container.RegisterInstance(typeof(IBus), activeBus);
}

Wenn der Bus gestartet wird, startet mein Meldungsmodul mit:

public void HandleBeginMessage()
{
    try
    {
        CurrentSessionContext.Bind(_sessionFactory.OpenSession());
    }
    catch (Exception e)
    {
        _log.Error("Error occurred in HandleBeginMessage of NHibernateMessageModule", e);
        throw;
    }
}

Beim Betrachten meines Protokolls wird der folgende Fehler protokolliert, wenn die Bindemethode aufgerufen wird:

System.NullReferenceException: Object reference not set to an instance of an object.
at NHibernate.Context.WebSessionContext.GetMap()
at NHibernate.Context.MapBasedSessionContext.set_Session(ISession value)
at NHibernate.Context.CurrentSessionContext.Bind(ISession session)

Anscheinend gibt es ein Problem beim Zugriff auf den HTTP-Kontext. Sollte dieser Aufruf zum Konfigurieren von NServiceBus später im Lebenszyklus als Application_Start erfolgen? Oder gibt es eine andere Problemumgehung, mit der andere Handler in einer Asp.NET-Webanwendung zum Arbeiten gebracht haben?

ielen Dank, Ste

Antworten auf die Frage(2)

Ihre Antwort auf die Frage