jolokia-jvm_Hawtio和Jolokia的Hibernate统计

本文介绍了如何在企业Java应用中利用Hibernate的统计信息,特别是通过Jolokia和Hawtio进行远程监控。通过启用Hibernate统计并在Spring中使用MBeanExporter,可以将JMX MBeans公开,然后通过Jolokia以JSON形式暴露给Hawtio,以Web控制台的方式查看和分析数据库操作的性能。
摘要由CSDN通过智能技术生成
jolokia-jvm

jolokia-jvm

企业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域树。 但是,为了实现这一点,我们首先需要找到一种将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中的扩展程序页面即可。 看起来像:

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-jvm

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值