- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
StackOverflow 中关于 NHibernate 和多个数据库(动态连接)的一些问题,让我相信最好的解决方案是保留 SessionFactory 的缓存(每个数据库)和配置的缓存,以更快地构建 SessionFactory。
我想知道这种方法是否正确,主要是:就每个实例的内存消耗和构建时间而言,SessionFactory 的“权重”是多少?
更多关于我的方法:
已知第一级和第二级缓存位于 SessionFactory“领域”中,我们可以假设内存消耗可能与打开的 ISession 数量(包括第一级缓存)有关。
对于第二个缓存级别,在我的情况下,数据库共享相同的架构并具有一些通用只读表,我可以使用全局缓存实现,在所有 SessionFactories 之间仅共享只读表,这对我的项目来说听起来不错。
我说得对吗?采用这种方法可能会出现什么样的性能和内存问题?考虑一个访问数百个(甚至数千个)数据库的 Web 应用程序(ASP.NET MVC,而不是 Webforms),在每个 HTTP 请求上,它需要查找用户数据库并解决对其的访问(获取、使用和处置 ISession)。
连接池:那么连接池呢?像这种方法一样,它应该具有什么样的行为来管理数百或数千个数据库的池? NHibernate 当前使用的一些实现可能会有所帮助,或者我需要构建自己的实现?
最佳答案
一些测试证实了一些人所说的关于构建 Configuration 和 SessionFactory 的时间和资源(CPU 和内存),展位很昂贵,但 SessionFactory 更贵得多。但不幸的是,我们只有单独的测试、经验结果,比如我的测试取决于我的类(class)模型。
所以,我一直相信我需要缓存 SessionFactory 和 Configuration,但是如果我们在 Web 解决方案中有数百个数据库,我们就会遇到一个大问题,因为 SessionFactory 需要内存,它是一个“内存吞噬者”,我可以得到接近 400 个实例时出现 OutOfMemoryException,我预计会达到数千个数据库。
好吧,当我们使用 SQLServer 时,我们设计了一个缓存,让每个 SQLServer 实例只有一个 SessionFactory,而不是每个数据库一个,因此在 ConnectionProvider 中我们可以注入(inject)一条 sql 命令 USE 'catalog-name'
准备每个连接,以便每个请求与其各自的数据库正常工作。
我希望其他有同样问题的人也可以探索来自 SQLServer 的资源,尽管有些数据库只允许您通过架构名称而不是数据库(目录名称)来做到这一点。
祝你好运。
关于.net - 使用 NHibernate 缓存多个数据库的 SessionFactory 和配置,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15488196/
我使用 hibernate 作为持久层来与数据库通信。我使用 maven 插件 hbm2java 来生成 dao、java、*hbm.xml 和 hibernate.cfg.xml。直到那个时候插件工
我想知道上面提到的 hibernates sessionfactory 类的两种方法之间的概念差异,如果可以通过简单的例子。 最佳答案 前者打开一个正常(有状态) session ,而后者(可能不足为
我正在关注 spring doc entry关于在独立应用程序中以编程方式设置我的应用程序上下文。 主要内容: public class Reporter { public static vo
如果我在结束时用 Session.getCurrentTransaction().commit() 关闭 session 或用 session.close() 关闭 session 会发生什么方法?
我正在尝试在我的 Spring 应用程序中使用 Hibernate 进行 Db 访问。但是现在,我收到以下错误: Could not locate SessionFactory in JNDI jav
我在基于 Java 的配置中使用 Hibernate 和 Spring。我的配置文件是这个: @Bean @Autowired public HibernateTransactionManager t
下面的代码不起作用。问题是事务没有在数据库中提交 案例1: @Transactional public void save(Person p) {
我对这两者有点困惑。据我所知,两者都返回 hibernate session ,SessionFactory.getCurrentSession()返回基于属性 的上下文 session 这是在 h
Image 错误: 1) AdminModel.java - 模型类。 2) HibernateUtil.java 促进 Hibernate DB 连接。 3) AdminDAO.java - 你们知
我遇到此错误,我找不到解决方案 我在Grails中使用postgres 这是不断发生的错误 org.springframework.beans.factory.BeanCreationExceptio
我需要 Hibernate 的一个特定功能,即 StatelessSession,为此我需要 Hibernate 的 SessionFactory。问题是我只有entityManagerFactory
我正在开发 jsf 应用程序并使用 hibernate 作为后端。我想创建 session 工厂并在整个应用程序中关闭它一次。我正在使用 util 类创建 session 工厂。 import org
我正在通过读取项目外部的属性文件来创建 session 工厂。我的属性文件如下, hibernate.connection.driver_class=com.mysql.jdbc.Driver hib
我们有一种情况,我们有多个具有相同模式的数据库,但每个数据库中的数据不同。我们正在创建一个 session 工厂来处理这个问题。 问题是我们不知道我们将连接到哪个数据库,直到运行时我们可以提供它。但是
在我的应用程序中,当我需要在这些方法中访问我的数据库时,我一直在我的方法参数中传递我的 SessionFatory。它在我的 Controller 中实例化,使用: @Autowired privat
我对 DataSource 和 SessionFactory 之间的区别感到困惑。 我认为SessionFactory是一个用于检索 session 的管理器(我猜这实际上是与数据库的连接)。 Dat
我正在尝试学习 spring 3 和 DAO 和 BO 类以及如何使用它进行 Autowiring ,我想知道这是连接 sessionFactory 的正确方法,因为我已经读到它更好地使用 publi
我正在将旧应用程序移植到 Hibernate 5,但在登录阶段遇到了问题。这是它的工作原理(我无法更改): 用户最初使用通用登录名/密码(所有用户相同)连接到 oracle DB 然后用户运行“登录”
根据文档,SessionFactory 应该是线程安全的: An ISessionFactory is threadsafe, many threads can access it concurren
如何使用 java 配置创建 SessionFactory? @Bean public SessionFactory sessionFactory(){ AnnotationSessionFa
我是一名优秀的程序员,十分优秀!