1

这是使用流利的 StructureMap 的 NH 的相关配置

ISessionFactory sessionFactory = fluentConfig.BuildSessionFactory();

For<Configuration>().LifecycleIs(new HybridLifecycle()).Singleton().Use(configuration);

For<ISessionFactory>().LifecycleIs(new HybridLifecycle()).Singleton().Use(sessionFactory);

For<ISession>().LifecycleIs(new ThreadLocalStorageLifecycle())
            .Use(x => x.GetInstance<ISessionFactory>().OpenSession());

For<IUnitOfWork>().LifecycleIs(new ThreadLocalStorageLifecycle())
            .Use<UnitOfWork>();

NH 会话被封装在一个 UnitOfWork 对象中。

在我的 Windows 服务中,每次我访问会话时,它都在一个线程池线程中,它像这样调用会话:

unitOfWork = ObjectFactory.GetInstance<IUnitOfWork>();
  ...
  //Init repositories with the unitOfWork
  //Have repos do their thing
  ...
unitOfWork.Commit();
unitOfWork.Dispose();

当我测试上述功能时,它总是在我第一次启动应用程序时工作,但在任何其他时间随机工作。它不起作用的时间,是因为会话为空。我发现如果我在上一次通话结束后等待大约 30 秒,下一次通话就会成功。

为什么会这样做?我正在尝试配置每个线程的会话?

4

1 回答 1

3

我会做两件事,

  1. 连接 Nlog 并在 Windows 服务方法中输出一些跟踪代码
  2. 连接 NHProf 并确保会话在您的 UOW 周围正确打开和关闭。

当我遇到会话问题时,​​我发现 NHProf 非常宝贵,它从未让我失望。

可以试用NHProf 30天,Nlog是OSS

于 2013-01-17T13:16:26.933 回答