jolokia_Hawtio和Jolokia的Hibernate统计

jolokia

企业Java的很大一部分处理数据。 在企业设置中使用数据的所有不同方式中,仍然存在使用任何种类的O / R映射的行之有效且广泛教授的方法。 JPA标准使每个人都比较容易使用它,并且它也应该是可移植的。 但是,我们不要谈论迁移细节。 O / R映射的最大缺点是,开发人员往往会失去与数据库上发生的事情的联系,甚至无法获得针对该数据库发出的确切SQL语句的联系。 这是这些项目遇到性能问题的第一原因。 如果您在那里,则需要分析根本原因并深入分析问题。 我最近发现了Hibernate的一个不错的功能,它使这一工作变得相当容易。

可用的统计信息和获取方法。

Hibernate最多提供3.5.x版本的统计信息和指标API,可让您了解幕后发生的事情。 统计接口API中对所有可用计数器进行了描述,分为三类:

  • 与常规会话使用率有关的度量标准,例如打开的会话数,检索到的JDBC连接等。
  • 与实体,集合,查询和缓存整体相关的指标(也称为全局指标)。
  • 与特定实体,集合,查询或缓存区域有关的详细指标。

例如,您可以检查实体,集合和查询的高速缓存命中率,未命中率和放置率,以及查询所需的平均时间。 请注意,在Java中,毫秒数是近似值。 Hibernate与JVM精度有关,在某些平台上,这可能仅精确到10秒。

简单的获取器用于访问全局度量(即不绑定到特定实体,集合,缓存区域等)。 您可以通过名称,通过其HQL或SQL表示形式访问特定实体,集合或缓存区域的指标。 有关更多信息,请参考Statistics, EntityStatisticsCollectionStatisticsSecondLevelCacheStatisticsQueryStatistics API Javadoc。

您要做的就是为您感兴趣的会话工厂启用统计信息,并检索统计数据以对其进行分析。 那里有很多示例如何在Spring中使用此功能。 原因很简单:Spring附带了一个传奇的MBeanExporter,它将JMX MBeans公开为Java对象。 想一想:Hibernate Statistics提供了一种通过JMX公开它们的简便方法。 但是,如果您仅组合了一些RedHat魔术,就无需使用Spring!

基本上,您可以通过两种不同的方式在已配置的设置中启用统计信息。 最简单的方法是向持久性单元配置添加属性:

<property name="hibernate.generate_statistics" value="true"/>

但是也可以手动启用它们。 有关如何执行此操作的更多详细信息,请参见社区WikiHibernate文档中的性能监控部分。

通过示例启用和公开统计信息

我创建了一个小示例独立的Hibernate应用程序,该应用程序具有两个实体和一个主要类,该类正在使用hibernate并初始化您需要了解的所有内容。 通过在GitHub上进行分叉,立即获得 。 这是一些简单的演练:

有两个强制性实体(部门和雇员)和META-INF / persistence.xml。 这是基本设置。 这里没有太多魔术。 您可以在persistence.xml中查看在何处启用统计信息(可能)。 该示例在主类JpaTest中启用它们。 但是,让我们从头开始。 main方法按顺序执行以下步骤:

  1. 创建要使用的EntityManager。
  2. 注册我们需要的统计Mbean。
  3. 初始化Jolokia服务器以通过JSON for Hawtio公开JMX
  4. 对实体做些事情。

魔术始于第二个步骤,该步骤位于registerHibernateMBeans(EntityManager manager)方法中。 它动手了PlatformMBeanServer,注册了相关的Hibernate JMX Mbean,设置了我们感兴趣的Session Factory并启用了统计信息。 那很容易。 现在,您已经注册了属性“ statistics”的JMX MBean“ Hibernate”。 如果您可以通过JConsole或Mission Control或VisualVM访问服务器,则可以简单地连接到该进程并浏览统计信息:

JConsole中的Hibernate MBean

JConsole中的Hibernate MBean


在生产环境中,这通常是根本不可能的。 因此,您需要找到一种通过http / https进行访问的方法。 在这里,我发现可以方便地将Hawtio用作用于管理Java东西的模块化Web控制台。 简而言之,这是一个带有插件的网络控制台。 它有大量的插件 ,可以自定义和扩展以满足您的需求。 今天,我们正在看一个非常简单的插件JMX plugin 。 它为您提供了底层JMX度量标准数据的原始视图,从而允许访问MBean的整个JMX域树。 但是为了实现这一点,我们首先需要找到一种向Hawtio公开JMX功能的方法。 这是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中的扩展程序页面即可。 看起来像:

Chrome中的Hawtio扩展

Chrome中的Hawtio扩展


如果您配置“ localhost”,“ 8778”和路径“ jolokia”,那么您都将开始浏览结果。 单击“连接”后,您可以浏览仪表板或切换到JMX视图并导航到Hibernate MBean:

使用Hawtio浏览JMX MBean

使用Hawtio浏览JMX MBean


来自DevNation 2014的Stan Lewis对Hawtio进行了更全面的介绍,等待您观看:

这是一个简短的例子。 继续阅读GitHub源代码,并随意研究Hawtio:

翻译自: https://www.javacodegeeks.com/2014/08/hibernate-statistics-with-hawtio-and-jolokia.html

jolokia

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值