企业Java的很大一部分处理数据。 在企业设置中使用数据的所有不同方式中,仍然存在使用任何种类的O / R映射的行之有效且广泛教授的方法。 JPA标准使每个人都可以轻松使用它,并且它也应该是可移植的。 但是,我们不要谈论迁移细节。 O / R映射的最大缺点是,开发人员往往会失去与数据库上发生的事情的联系,甚至无法与数据库发出确切的SQL语句。 这是这些项目遇到性能问题的第一原因。 如果您在那里,则需要分析根本原因并深入分析问题。 我最近发现了Hibernate的一个不错的功能,它使这一工作变得相当容易。
可用的统计信息和获取方法。
Hibernate最多提供3.5.x版本的统计信息和指标API,可让您了解幕后发生的事情。 在统计信息接口API中 ,将所有可用的计数器分为三类:
- 与常规会话使用率有关的度量标准,例如打开的会话数,检索到的JDBC连接等。
- 与实体,集合,查询和缓存整体相关的指标(也称为全局指标)。
- 与特定实体,集合,查询或缓存区域相关的详细指标。
例如,您可以检查实体,集合和查询的高速缓存命中率,未命中率和放置率,以及查询所需的平均时间。 请注意,在Java中,毫秒数是近似值。 Hibernate与JVM精度有关,在某些平台上,这可能仅精确到10秒。
简单的获取器用于访问全局度量(即不绑定到特定实体,集合,缓存区域等)。 您可以通过名称,通过其HQL或SQL表示来访问特定实体,集合或缓存区域的度量。 有关更多信息,请参考Statistics, EntityStatistics , CollectionStatistics , SecondLevelCacheStatistics和QueryStatistics API Javadoc。
您要做的就是为您感兴趣的会话工厂启用统计信息,并检索统计信息以对其进行分析。 那里有很多示例如何在Spring中使用此功能。 原因很简单:Spring附带了一个传奇的MBeanExporter,它将JMX MBeans公开为Java对象。 并猜测一下:Hibernate Statistics提供了一种通过JMX公开它们的简便方法。 但是,如果您仅组合使用更多RedHat魔术,则无需使用Spring!
基本上,您可以通过两种不同的方式在配置的设置中启用统计信息。 最简单的方法是向持久性单元配置中添加属性:
<property name="hibernate.generate_statistics" value="true"/>
但是也可以手动启用它们。 有关如何执行此操作的更多详细信息,请参见社区Wiki和Hibernate文档中的性能监视部分。
通过示例启用和公开统计信息
我创建了一个小示例独立的Hibernate应用程序示例,其中包含两个实体和一个主类,该主类正在使用hibernate并初始化您需要了解的所有内容。 通过在GitHub上进行分叉,立即获得它 。 这是一些简单的演练:
有两个强制性实体(部门和雇员)和META-INF / persistence.xml。 这是基本设置。 这里没有太多魔术。 您可以在persistence.xml中查看在何处启用统计信息(可能)。 该示例在主类JpaTest中启用它们。 但是,让我们从头开始。 main方法按顺序执行以下步骤:
- 创建要使用的EntityManager。
- 注册我们需要的统计Mbean。
- 初始化Jolokia服务器以通过JSON for Hawtio公开JMX
- 对实体做些事情。
魔术始于第二个步骤,该步骤位于registerHibernateMBeans(EntityManager manager)方法中。 它动手了PlatformMBeanServer,注册了相关的Hibernate JMX Mbean,设置了我们感兴趣的Session Factory并启用了统计信息。 那很简单。 现在,您已经注册了属性“ statistics”的JMX MBean“ Hibernate”。 如果您可以通过JConsole或Mission Control或VisualVM访问服务器,则可以简单地连接到该进程并浏览统计信息:
在生产环境中,这通常是根本不可能的。 因此,您需要找到一种通过http / https进行访问的方法。 在这里,我发现可以方便地将Hawtio用作用于管理Java东西的模块化Web控制台。 简而言之,这是一个带有插件的网络控制台。 它有大量的插件 ,可以自定义和扩展以满足您的需求。 今天,我们正在看一个非常简单的插件JMX plugin 。 它为您提供了基础JMX度量标准数据的原始视图,从而允许访问MBean的整个JMX域树。 但是,为了实现这一点,我们首先需要找到一种将JMX功能公开给Hawtio的方法。 这是Jolokia出现的地方。其中有一个JVM代理 ,可以通过JSON公开JMX MBean。 您所需要做的就是像这样初始化并启动服务器:
JolokiaServerConfig config = new JolokiaServerConfig(new HashMap<String, String>());
JolokiaServer jolokiaServer = new JolokiaServer(config, true);
jolokiaServer.start();
现在您可以尝试使用Hawtio控制台了。 查看快速入门 ,看看有什么可能。 对于本示例,我仅使用Google Chrome扩展程序,您只需下载并拖动到Chrome中的扩展程序页面即可。 看起来像:
如果您配置“ localhost”,“ 8778”和路径“ jolokia”,那么您都将开始浏览结果。 单击“连接”后,您可以浏览仪表板或切换到JMX视图并导航到Hibernate MBean:
来自DevNation 2014的Stan Lewis对Hawtio进行了更全面的介绍,等待您观看:
这是一个简短的例子。 继续阅读GitHub源代码,并随意研究Hawtio:
- 阅读入门指南,以了解如何在您自己的环境中下载和安装Hawtio。
- 阅读有关如何在各种环境中配置Hawtio的信息 ,例如配置安全性以及Hawtio的存储位置。
- 查看如何在WildFly上配置Hawtio 。
- 我们更喜欢使用问题跟踪器来处理想法和问题 ,但是如果您只想谈论Hawtio的所有事情,请加入我们的邮件列表 。
- 在GitHub上找到Hawtio源代码 。
翻译自: https://www.javacodegeeks.com/2014/08/hibernate-statistics-with-hawtio-and-jolokia.html