微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

asp.net-mvc – Web场中的nHibernate策略

我们当前的工作项目是一个新的MVC网站,它将主要使用WCF服务通过Web服务访问第三方计费系统,以及用于个性化用户的小型sql数据库. WCF服务将nHibernate用于sql数据库.

我们希望实现某种Web场以实现负载平衡以及故障转移和维护.如果有多个WCF服务在运行,我正在尝试决定处理nHibernate缓存和数据库并发的最佳方法.

我一直在考虑的一些场景……

1)多个IIS服务器,一个WCF服务器.使用此设置,WCF服务器将是单点故障,但nHibernate缓存或数据库并发性不会出现问题.

2)多个IIS服务器,每个服务器都有自己的WCF服务.这消除了单点故障,但现在一台机器上的nHibernate不知道另一台机器完成的数据库更改.

对于数字2的一些解决方案是使用IStatelessSession,因此我们不进行任何缓存,并且nHibernate总是直接从数据库获取.这可能是最可行的,因为我们的个性化数据库中只有很少的对象.我也在考虑二级缓存,例如memcached或VeLocity,但这对于这个系统来说可能有些过分.

我把它放在那里,看看是否有人有这种架构的经验,并获得一些解决方案的想法.谢谢!

解决方法

在这里遗漏了什么,我没有看到网络服务器上的nhibernate有问题.
应用程序缓存不会有问题,因为每个nhibernate框都会保留自己的缓存,这些缓存将从数据存储区填充.查看创建一个可以监视的表,以便进行缓存刷新.我们曾经使用.net 2.0中的CacheDependency类来执行此操作,该类将检测对列的更改,然后从缓存中删除相关项.因此,如果用户插入新产品,缓存将被删除,下一次获取产品的调用将再次加载缓存.这是旧的但退房: http://msdn.microsoft.com/en-us/magazine/cc163955.aspx#S2的概念.干杯

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐