- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我已经通过 hibernate 为我的应用程序使用 h2 (1.3.172) 一段时间了,在解决了一些非 h2 性能问题之后,我的性能瓶颈是 h2。我的数据库非常简单,有 10 个表,每个表的记录量不到 100,000 条记录,在 h2 功能范围内也是如此,但我认为问题出在多线程上。
我实际上是在使用 hibernate/h2 来控制我的应用程序中的内存消耗。我的应用程序使用管道方法处理文件,对可以处理的文件数量没有限制,因此如果我将数据存储在内存中,我会很快遇到 OutOfMemory。每个文件通常经过十个处理阶段,每个阶段都有自己的执行器服务,当文件从一个阶段移动到另一个阶段时,它会作为相关执行器服务上的作业添加。内存中存储的数据很少,而是在执行程序上启 Action 业时从数据库中检索有关文件的数据,并在作业完成时将数据写回数据库。我们有 10 个执行器,每个执行器都有机器内核大小的线程池,所以在 4 个机器内核上,理论上我们可以随时向数据库发出 40 个请求,但通常情况下我们只有不到 10 个。所以我们有许多事务正在进行主要同时涉及少量行。
我的应用程序是多线程的,如果我对其运行分析器,我会发现大部分时间我的线程处于阻塞状态,等待 executeQuery() 或 executeUpdate()。我读到 h2 是单线程的,所以我认为问题是由 h2 同步请求引起的,而不是锁定,但我可能误解了这一点。我已经设置了 MVCC=TRUE 以便 h2 进行行锁定而不是表锁定,但我仍然会遇到偶尔的超时 - 是否可以设置一些东西来检查正在使用的锁。
我读到有一个 MULTI_THREADING 选项,但它不能与 MVCC 一起使用,这很遗憾,因为我觉得如果我删除 MVCC=TRUE 我需要两个选项,这意味着 h2 将在我每次插入或插入时锁定表更新,因为我只有几个表,它们几乎总是被锁定。
所以,我觉得可以大大减少阻塞,但我不清楚潜在的问题是什么以及如何进行
测试这是我的起点,测试用例需要 3 分 14 秒
3:14,FILE_LOCK=SOCKET;MVCC=TRUE;DB_CLOSE_ON_EXIT=FALSE
我尝试了各种组合,例如
3:02,FILE_LOCK=SOCKET;MVCC=TRUE;DB_CLOSE_ON_EXIT=FALSE;LOG=0;CACHE_SIZE=65536;LOCK_MODE=0;
2:56,FILE_LOCK=SOCKET;MVCC=TRUE;DB_CLOSE_ON_EXIT=FALSE;LOG=0;;CACHE_TYPE=SOFT_LRU;LOCK_MODE=0;
1:05,FILE_LOCK=SOCKET;DB_CLOSE_ON_EXIT=FALSE;LOCK_TIMEOUT=10000
我发现唯一产生巨大差异的是删除了 MVCC=TRUE 选项,但不幸的是我的锁超时次数从几乎为零增加到加载,所以不幸的是一些所需的处理没有发生,这可能是总时间更快的原因 因为应用程序中的某些阶段未完成,或者使用 MVCC 会减慢速度。
我尝试使用 MULTI_THREADED=TRUE 但它似乎对我根本不起作用
关于在多核系统中的使用
我刚刚阅读了 MULTI_THREADED 选项的解释 https://groups.google.com/forum/#!topic/h2-database/VoE3AU7mSuM
托马斯说
The default is "not multi-threaded" meaning only one statement can run at any time (per database). There is a synchronized block around running a statement. When multi-threaded is enabled, then the synchronized statement is on the session (connection) instead of on the database object.
The option is to increase concurrency, not throughput. The default setting is usually not a problem except if you have long running queries.
如果我理解正确,这意味着当禁用时,虽然 h2 可以接受多个连接,但它一次只会处理一个查询,但即使启用它,它也会在查询中途交换,但实际上仍然只是一次处理一个查询,即它可以开始处理查询 1,然后交换到查询 2,然后返回查询 1 等等,但永远不会实际使用 cpu 并行处理查询 1 和查询 2。
所以在任何一种情况下,尽管在 cpu 之间切换,它在任何时候都只会使用一个 cpu。因此,如果您有一台功能强大的机器,例如有 16 个内核,而瓶颈是数据库,那么添加更多内核根本无济于事因为 h2 一次只使用一个内核?
这似乎是一个真正的限制,我想知道它与 Derby 或任何其他嵌入式 Java 数据库相比如何。
最佳答案
有些线程被阻塞,可能是,是的,但我会首先专注于那些未被阻塞的线程,这意味着它们正在消耗 CPU时间或磁盘 I/O。那些陈述是什么?他们是不使用索引的查询吗?你有索引吗?或者您是否不必要地插入/删除行?另请参阅有关 how to analyze performance problems 的文档.
关于hibernate - 我怎样才能阻止 h2 如此频繁地阻止我的 hibernate 查询,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18782331/
什么是 hibernate 和n- hibernate ?我可以在 Visual Studio 2008 中使用它进行 C# Web 应用程序开发吗?请给我建议...我是 asp.net Web 应用
我有一个不系统地发生的异常(exception)。 我试图通过在每次迭代中刷新和清理 session 来解决此问题,但没有成功。 [quartzScheduler_Worker-7] ERROR jd
使用 Hibernate 在数据库中存储 IP 地址的最佳类型是什么? 我虽然是 Byte[] 或 String,但有没有更好的方法,或者你用什么? @Column(name = "range_fr
我正在尝试制定一个公式来选择用户个人资料的用户友好名称。它选择名字 + ' ' + 姓氏 如果其中至少有一个不为空且不为空(包含非空白字符),否则选择 短名称 (条件相同),最后,如果 短名称 为空或
在hibernate中,是否可以将鉴别器作为一个实体?例如,如果我将 Department 作为基类,将 AdminDepartment 和 ProcessingDepartment 作为子类。 De
我只想从表中获取一些列值。因此,我已经使用投影来实现这一目标。该代码有效,但我认为它无效。 我的问题是当我使用ProjectionsList并将标准条件列表设置为ArrayList时-Bulletin
你好: 我对 hibernate 缓存缓存的内容感到困惑。 从文档中,我知道 hibernate 中有缓存类型。 一级 :交易级别。 似乎要被 session 持久化的实体被缓存在这里。 二级缓存 :
我遇到了一个情况: save或update hibernate 的目标表中的某些数据 在目标表上有一个触发器,该触发器将在目标表的insert或update操作之前执行 由 hibernate 将此记
我有一个名为 Master_Info_tbl 的表。它是一个查询表: 这是该表的代码: @Entity @Table(name="MASTER_INFO_T") public class Code
我想知道如何在 Hibernate 查询语言中使用日期文字。我在我的 JPA 项目中做了如下操作(作为 Eclipselink 提供者)并且它工作正常。 SELECT m FROM Me m WHER
@Entity public class Troop { @OneToMany(mappedBy="troop") public Set getSoldiers() { ...
我正在尝试使用 hibernate 查询删除表 'user_role' 中的所有行。但每次我都会出错。有人可以帮我吗。 DaoImpl @Override public void deleteAll(
不是将数据库操作分散在四个 (osgi) 包中,而是在那里做略有不同的事情。我想创建一个负责所有持久性问题的(简单的)OSGi 包。我觉得这并不像听起来那么简单,因为“每个包都有独特的类加载器”。 因
这就是我使用生成器的方式: private Integer id; 我看到的行为是: 创建第一个对象 hibernate 分配 id = 1 删除该对象 关闭服务
对象级别的实体和值类型有什么区别。我知道实体将有一个 id 但值不会,但为什么我们需要不同的方法来映射实体与值类型? 这样做是为了让hibernate可以对值类型应用任何优化吗? 最佳答案 一个实体已
我正在使用 HibernateTemplate.findByCriteria 方法进行一些查询。现在我想在标准上创建一些 SQL 限制,比如 criteria.add(Restrictions.sql
所以我有以下代码: Query query = session.createQuery("from Weather"); List list = query.list();
如何使用Hibernate映射具有多个实体的 View ? 问候, 混沌 最佳答案 请参见Hibernate文档中第5.1.3节“类”,紧接在“Id”节之前: There is no differen
据我所知,Hibernate 有两种类型的实现 JPA的实现(2)(@Entity,@Table注解) 扩展到旧的(传统的) hibernate (没有 JPA),使用 HSQL 查询,没有注释 如果
我需要一个将条目存储为键值对的集合(因此我可以通过键查找值),但我需要一个允许多个值使用 hibernate 共享同一个键的集合 最佳答案 一个键具有多个值的映射称为多映射 - 在 Apache 公共
我是一名优秀的程序员,十分优秀!