fya*_*sar 5 nhibernate fluent-nhibernate
我在IIS上创建了一个多线程应用程序(ASP.NET MVC),当线程服务器启动时,它创建了10个线程,并将工作项目引入线程.
通常我的应用程序运行良好,但有一段时间我有错误,我确信问题来自流畅的配置.我再次确定我犯了一些错误:)
这是我的SessionFactory类:
public class NHibernateHelper
{
private static ISessionFactory sessionFactory;
/// <summary>
/// SessionFactory is static because it is expensive to create and is therefore at application scope.
/// The property exists to provide 'instantiate on first use' behaviour.
/// </summary>
private static ISessionFactory SessionFactory
{
get
{
if (sessionFactory == null)
{
sessionFactory = CreateSessionFactory();
}
return sessionFactory;
}
}
/// <summary>
/// CreateSessionFactory
/// </summary>
/// <returns></returns>
private static ISessionFactory CreateSessionFactory()
{
IPersistenceConfigurer dbConfigurer = MsSqlConfiguration.MsSql2005
.ConnectionString("connection string ..")
.Cache(c => c
.UseQueryCache()
.ProviderClass<NoCacheProvider>()
).ShowSql()
.CurrentSessionContext<ThreadStaticSessionContext>();
return Fluently
.Configure()
.Database(dbConfigurer)
.Mappings(mc =>
{
mc.FluentMappings.Add(typeof(UserMap));
mc.FluentMappings.Add(typeof(ApplicationMap));
mc.FluentMappings.Add(typeof(SubscriptionsMap));
})
.BuildSessionFactory();
}
public static ISession GetCurrentSession()
{
if (!CurrentSessionContext.HasBind(SessionFactory))
{
CurrentSessionContext.Bind(SessionFactory.OpenSession());
}
return SessionFactory.GetCurrentSession();
}
public static void DisposeSession()
{
var session = GetCurrentSession();
session.Close();
session.Dispose();
}
public static void BeginTransaction()
{
GetCurrentSession().BeginTransaction();
}
public static void CommitTransaction()
{
var session = GetCurrentSession();
if (session.Transaction.IsActive)
session.Transaction.Commit();
}
public static void RollbackTransaction()
{
var session = GetCurrentSession();
if (session.Transaction.IsActive)
session.Transaction.Rollback();
}
}
Run Code Online (Sandbox Code Playgroud)
每个线程都在调用NHibernateHelper类,并在其内部使用此行;
var myobjectinstance = new ObjectInstance();
NHibernateHelper.GetCurrentSession().Save( myobjectinstance );
Run Code Online (Sandbox Code Playgroud)
我看到了,当我启动服务器时,它已成功调用300.000工作项进行测试.但有时它会给出2-3个工作项的错误.
例外是:
[0] = {"An invalid or incomplete configuration was used while creating a SessionFactory. Check PotentialReasons collection, and InnerException for more detail.\r\n\r\n"}
Run Code Online (Sandbox Code Playgroud)
内在的例外是:
Object reference not set to an instance of an object.
Run Code Online (Sandbox Code Playgroud)
内部异常堆栈跟踪是:
at System.Collections.Generic.Dictionary`2.Insert(TKey key, TValue value, Boolean add)
at System.Collections.Generic.Dictionary`2.set_Item(TKey key, TValue value)
at NHibernate.Impl.SessionFactoryObjectFactory.AddInstance(String uid, String name, ISessionFactory instance, IDictionary`2 properties)
at NHibernate.Impl.SessionFactoryImpl..ctor(Configuration cfg, IMapping mapping, Settings settings, EventListeners listeners)
at NHibernate.Cfg.Configuration.BuildSessionFactory()
at FluentNHibernate.Cfg.FluentConfiguration.BuildSessionFactory()
in d:\Builds\FluentNH\src\FluentNHibernate\Cfg\FluentConfiguration.cs:line 93
Run Code Online (Sandbox Code Playgroud)
欢迎提出任何建议或帮助
看起来这个CreateSessionFactory方法被多次调用.在sessionFactory静态字段的访问是不是在这个方法中,这使得它不是线程安全的同步:
private static ISessionFactory SessionFactory
{
get
{
if (sessionFactory == null)
{
sessionFactory = CreateSessionFactory();
}
return sessionFactory;
}
}
Run Code Online (Sandbox Code Playgroud)
确保始终在多线程应用程序中同步对共享资源的访问.在这种情况下有一种常见的使用模式叫做singleton.
| 归档时间: |
|
| 查看次数: |
5149 次 |
| 最近记录: |