在Hibernate,EhCache,Quartz,DBCP和Spring中启用JMX

继续使用JMX的过程(请参阅: 人类JMX ),我们将学习如何在一些流行的框架中启用JMX支持(通常是统计和监视功能)。 这些信息大部分都可以在项目的主页上找到,但是我决定在收集这些信息的同时,很少添加一些有用的提示。

休眠(带有Spring支持)
使用JMX公开Hibernate统计信息非常简单 ,但是当使用JPA API获取基础SessionFactory时,需要一些讨厌的解决方法

class JmxLocalContainerEntityManagerFactoryBean() extends LocalContainerEntityManagerFactoryBean {override def createNativeEntityManagerFactory() = {val managerFactory = super.createNativeEntityManagerFactory()registerStatisticsMBean(managerFactory)managerFactory}def registerStatisticsMBean(managerFactory: EntityManagerFactory) {managerFactory match {case impl: EntityManagerFactoryImpl =>val mBean = new StatisticsService();mBean.setStatisticsEnabled(true)mBean.setSessionFactory(impl.getSessionFactory);val name = new ObjectName("org.hibernate:type=Statistics,application=spring-pitfalls")ManagementFactory.getPlatformMBeanServer.registerMBean(mBean, name);case _ =>}}}

请注意,我已经创建了Springs内置LocalContainerEntityManagerFactoryBean的子类。 通过重写createNativeEntityManagerFactory()方法,我可以访问EntityManagerFactory并尝试将其向下转换为org.hibernate.ejb.EntityManagerFactoryImpl我们能够注册Hibernate Mbean。

还有一件事。 显然,我们必须使用自定义子类而不是org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean 。 另外,为了收集实际的统计信息,而不是一直看到零,我们必须设置hibernate.generate_statistics标志。

@Bean
def entityManagerFactoryBean() = {val entityManagerFactoryBean = new JmxLocalContainerEntityManagerFactoryBean()entityManagerFactoryBean.setDataSource(dataSource())entityManagerFactoryBean.setJpaVendorAdapter(jpaVendorAdapter())entityManagerFactoryBean.setPackagesToScan("com.blogspot.nurkiewicz")entityManagerFactoryBean.setJpaPropertyMap(Map("hibernate.hbm2ddl.auto" -> "create","hibernate.format_sql" -> "true","hibernate.ejb.naming_strategy" -> classOf[ImprovedNamingStrategy].getName,"hibernate.generate_statistics" -> true.toString).asJava)entityManagerFactoryBean
}

这是我们希望在JvisualVM中看到的示例(不要忘记安装所有插件!):

另外,我们获得了一个不错的Hibernate日志记录:

HQL: select generatedAlias0 from Book as generatedAlias0, time: 10ms, rows: 20

高速缓存

监视缓存非常重要,尤其是在您希望在那里通常存在值的应用程序中。 我倾向于根据需要频繁查询数据库,以避免不必要的方法参数或本地缓存 。 一切使代码尽可能简单。 但是,这种方法仅在数据库层上的缓存正常工作时才有效。 与Hibernate相似,在EhCache中启用JMX监视是一个两步过程。 首先,您需要在MBeanServer公开提供的MBean

@Bean(initMethod = "init", destroyMethod = "dispose")
def managementService = new ManagementService(ehCacheManager(), platformMBeanServer(), true, true, true, true, true)@Bean def platformMBeanServer() = ManagementFactory.getPlatformMBeanServerdef ehCacheManager() = ehCacheManagerFactoryBean.getObject@Bean def ehCacheManagerFactoryBean = {val ehCacheManagerFactoryBean = new EhCacheManagerFactoryBeanehCacheManagerFactoryBean.setShared(true)ehCacheManagerFactoryBean.setCacheManagerName("spring-pitfalls")ehCacheManagerFactoryBean
}

请注意,我明确设置了CacheManager名称。 这不是必需的,但是此名称用作Mbean名称的一部分,并且默认名称包含hashCode值,这不是很好。 最后一点是启用基于缓存的统计信息:

<cache name="org.hibernate.cache.StandardQueryCache"maxElementsInMemory="10000"eternal="false"timeToIdleSeconds="3600"timeToLiveSeconds="600"overflowToDisk="false"memoryStoreEvictionPolicy="LRU"statistics="true"
/>

现在,我们可以愉快地分别监视每个缓存的各种缓存特征:

如我们所见,缓存未命中的百分比增加了。 从来没有一件好事。 如果我们不启用缓存统计信息,那么启用JMX仍然是一个好主意,因为我们免费获得了许多管理操作,包括刷新和清除缓存(在调试和测试过程中很有用)。

石英调度器

以我的拙见, Quartz Scheduler是一个被低估的库,但是我将自己撰写一篇有关它的文章。 这次,我们将仅学习如何通过JMX对其进行监视。 幸运的是,它就像添加一样简单:

org.quartz.scheduler.jmx.export=true

quartz.properties文件。 Quartz中对JMX的支持可能会稍微扩大一点,但是仍然可以查询例如当前正在运行的作业。 顺便说一下,新的主要版本的Quartz(2.x)带来了非常好的DSL类似的调度支持:

val job = newJob(classOf[MyJob])
val trigger = newTrigger().withSchedule(repeatSecondlyForever()).startAt(futureDate(30, SECOND))
scheduler.scheduleJob(job.build(), trigger.build())

Apache Commons DBCP

Apache Commons DBCP是我遇到的最合理的JDBC池库。 还有c3p0 ,但似乎不再积极开发了。 Tomcat JDBC连接池看起来很有前途,但是由于它捆绑在Tomcat中,因此您的JDBC驱动程序不能再打包在WAR中。

DBCP的唯一问题是它不支持JMX。 完全没有(请参见此两年半的旧版 )。 幸运的是,这很容易解决。 此外,我们还将学习如何使用Spring内置的JMX支持。

看起来标准的BasicDataSource拥有我们所需的全部,我们要做的就是通过JMX公开现有的指标。 使用Spring时,它简直就是简单–只需@ManagedAttribute子类,然后在所需的属性上添加@ManagedAttribute批注:

@ManagedResource
class ManagedBasicDataSource extends BasicDataSource {@ManagedAttribute override def getNumActive = super.getNumActive@ManagedAttribute override def getNumIdle = super.getNumIdle@ManagedAttribute def getNumOpen = getNumActive + getNumIdle@ManagedAttribute override def getMaxActive: Int= super.getMaxActive@ManagedAttribute override def setMaxActive(maxActive: Int) {super.setMaxActive(maxActive)}@ManagedAttribute override def getMaxIdle = super.getMaxIdle@ManagedAttribute override def setMaxIdle(maxIdle: Int) {super.setMaxIdle(maxIdle)}@ManagedAttribute override def getMinIdle = super.getMinIdle@ManagedAttribute override def setMinIdle(minIdle: Int) {super.setMinIdle(minIdle)}@ManagedAttribute override def getMaxWait = super.getMaxWait@ManagedAttribute override def setMaxWait(maxWait: Long) {super.setMaxWait(maxWait)}@ManagedAttribute override def getUrl = super.getUrl@ManagedAttribute override def getUsername = super.getUsername
}

以下是一些在负载测试期间疯狂的数据源指标:

Spring框架本身对JMX的支持非常简单。 如您所见,公开任意属性或操作只是添加注释的问题。 您只需要记住有关使用XML或Java启用JMX支持的方法(另请参见: SPR-8943:等效于<context:mbean-export />的@Configuration ):

<context:mbean-export/>

要么:

@Bean def annotationMBeanExporter() = new AnnotationMBeanExporter()

这篇文章并不特别令人兴奋。 但是,对JMX指标的了解将使我们能够立即编写简单而精致的仪表板。 敬请关注!

参考: Java和社区博客上的JCG合作伙伴 Tomasz Nurkiewicz提供了在Hibernate,EhCache,Quartz,DBPC和Spring中启用JMX的信息 。

相关文章 :

  • 使用Spring将POJO公开为JMX MBean
  • 休眠陷阱
  • DataNucleus 3.0与Hibernate 3.5
  • Spring 3.1和Hibernate的持久层
  • 使用Spring和Java泛型简化数据访问层
  • Spring 3.1和JPA的持久层

翻译自: https://www.javacodegeeks.com/2012/01/enabling-jmx-in-hibernate-ehcache-qurtz.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/374452.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

二叉树遍历(前中后)

二叉树前序遍历&#xff1a; /*** Definition for binary tree* struct TreeNode {* int val;* TreeNode *left;* TreeNode *right;* TreeNode(int x) : val(x), left(NULL), right(NULL) {}* };*/ class Solution { public:vector<int> preorderTravers…

python语言程序设计实践教程答案实验六_Python程序设计实践教程

书名&#xff1a;Python程序设计实践教程 定价&#xff1a;29.8 ISBN&#xff1a;9787115532602 作者&#xff1a;储岳中 薛希玲 版次&#xff1a;*1版 出版时间&#xff1a;2020-04 内容提要&#xff1a; 本书是Python语言程序设计的配套实践教材&#xff0c;分为三部分&#…

400多万微信用户如何“变现”?凯叔说了五大秘诀与教训

凯叔&#xff0c;原名王凯&#xff0c;自媒体“凯叔讲故事”创始人&#xff0c;近日在狮享家班委会上做了分享&#xff0c;全是实实在在的实验性方法论。以下是王凯的分享内容&#xff0c;整理 / 垅青 我讲的主题叫“基于内容的MVP探索”&#xff0c;MVP是什么东西&#xff1f;…

使用dbUnit,JSON,HSQLDB和JUnit规则进行数据库单元测试

在本周TDD课程的运行中&#xff0c;我认为编写一些夹具以简化dbUnit的使用将很有趣。 我最初的想法只是教dbUnit有关JSON的知识&#xff0c;但事实证明Lieven Doclo已经做到了。 因此&#xff0c;我决定更进一步&#xff0c;还将dbUnit与JUnit Rules结合起来&#xff0c;并提供…

Codeforces Round #321 (Div. 2) E. Kefa and Watch 线段树hash

E. Kefa and Watch Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/contest/580/problem/EDescription One day Kefa the parrot was walking down the street as he was on the way home from the restaurant when he saw something glittering by…

python文字游戏源代码求年纪_Python实现猜年龄游戏代码实例

1. 在猜年龄的基础上编写登录、注册方法&#xff0c;并且把猜年龄游戏分函数处理&#xff0c;如 2. 登录函数 3. 注册函数 4. 猜年龄函数 5. 选择奖品函数 代码如下 import json real_age 18 prize_list [好迪洗发水, 绿箭侠, 小猪佩奇, 布娃娃, 再来一次!] import random us…

KVC 与 KVO

一、Key-Value Coding (KVC)键值编码 KVC&#xff0c;即是指 NSKeyValueCoding&#xff0c;一个非正式的 Protocol&#xff0c;提供一种机制来间接访问对象的属性。KVO 就是基于 KVC 实现的关键技术之一。 一个对象拥有某些属性。比如说&#xff0c;一个 Person 对象有一个 nam…

使用模拟的单元测试–测试技术5

我的最后一个博客是有关测试代码方法的一系列博客中的第四篇&#xff0c;演示了如何创建使用存根对象隔离测试对象的单元测试。 今天的博客探讨了有时被视为对立的技术&#xff1a;使用模拟对象进行单元测试。 同样&#xff0c;我使用了从数据库检索地址的简单方案&#xff1a;…

多线程中的volatile和伪共享

伪共享 false sharing&#xff0c;顾名思义&#xff0c;“伪共享”就是“其实不是共享”。那什么是“共享”&#xff1f;多CPU同时访问同一块内存区域就是“共享”&#xff0c;就会产生冲突&#xff0c;需要控制协议来协调访问。会引起“共享”的最小内存区域大小就是一个cache…

C语言代码规范(一)缩进与换行

一、缩进的空格数为4个。最好配置代码编辑器将TAB键设置为空格替换&#xff0c;避免出现另一个编辑器打开时格式变乱的情况。 例如Notepad设置 KEIL设置 二、“{” 和 “}”各自独占一行。 不规范例子&#xff1a; for(i 0; i < student_num; i) { if((score[i] > 0…

armv7 cortex a系列编程手册_AWTK能为现代GUI编程带来何种改变?

AWTK是一个伸缩性极强的嵌入式图形框架&#xff0c;它的诞生会给GUI编程研发工程师带来哪些改变&#xff1f;AWTK是一个伸缩性极强的嵌入式图形框架&#xff0c;可在Cortex-M3这样低端的单片机上运行&#xff0c;也可以在Cortex-A7/A8/A9等处理器&#xff0c;甚至DSP以及X86处理…

【转】各种概念POJO、JAVABEAN、DAO、DTO、PO、VO、BO、SSH、EJB

POJO&#xff08;pure old java object&#xff09; 是普通java类&#xff0c;有一些private的参数作为对象的属性&#xff0c;然后针对每一个参数定义get和set方法访问的接口。我看到这个定义&#xff0c;心里就有个疑问了&#xff0c;这个POJO跟JavaBean的定义怎么就这么像&a…

为什么要编写单元测试–测试技巧8

我对最近在“您应该测试什么”上的博客有很多反应&#xff0c;有些人出于各种原因同意我的想法&#xff0c;另一些人则认为建议某些类可能不需要单元测试是非常危险的。 已经处理了什么测试&#xff0c;今天的博客涉及为什么要编写单元测试&#xff0c;而今天的示例代码是基于一…

Git迁移 从SVN到Git

Migrating from SVN to Git 首先我们需要在Stach或者GitHub上新建一个Repository, 拿到它的URL。 接下来参照如下步骤 : At first we should create a new git repository at Stash and get the repository URL, and then follow below steps: 1. 切换到本地git工作目录 chang…

C语言代码规范(二)空格

一、逗号, 之后加空格 printf("error! score[%d] %d\n", i, score[i]); 二、分号; 之后加空格 for(i 0; i < student_num; i) 三、关系运算符<、<、>、>、、! 前后加空格 if( (score[i] > 0) && (score[i] < 100) ) 四、赋值运算符…

c++ 多重背包状态转移方程_动态规划入门——详解经典问题零一背包

本文始发于个人公众号&#xff1a;TechFlow&#xff0c;原创不易&#xff0c;求个关注今天是周三算法与数据结构专题的第12篇文章&#xff0c;动态规划之零一背包问题。在之前的文章当中&#xff0c;我们一起探讨了二分、贪心、排序和搜索算法&#xff0c;今天我们来看另一个非…

Discuz! 的编码规范

前言 本规范由编程原则组成&#xff0c;融合并提炼了开发人员长时间积累下来的成熟经验&#xff0c;意在帮助形成良好一致的编程风格。适用范围 如无特殊说明&#xff0c;以下规则要求完全适用于Discuz!项目&#xff0c;同时也可大部分适用于COMSENZ旗下其他PHP项目。标准化的重…

C语言代码规范(三)if语句

一、整型变量与0比较 许多人为了一时之便&#xff0c;模仿布尔变量风格写为如下代码 if(value) {... }if(!value) {... } 应当用 或 ! 来与0比较 if(0 value) {... }if(0 ! value) {... } 二、当if内的语句是与常量进行比较时&#xff0c;常量为左值&#xff0c;变量为右…

6月24 面向对象的设计原则-----工厂模式和单列模式

工厂模式&#xff1a; 工厂模式就是专门负责将大量有共同接口的类实例化&#xff0c;而且不必事先知道每次是要实例化哪一个类的模式。它定义一个用于创建对象的接口&#xff0c;由子类决定实例化哪一个类。 工厂模式相当于创建实例对象的new&#xff0c;经常要根据类Class生成…

LeetCode Subsets

原题链接在这里&#xff1a;https://leetcode.com/problems/subsets/ 题目&#xff1a; Given a set of distinct integers, nums, return all possible subsets. Note: Elements in a subset must be in non-descending order.The solution set must not contain duplicate su…