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