概述
因为项目需要增加JMX 监控,SO翻了翻官方文档,有几种实现方式,下面说一个我选择的,一是方便扩展,二是方便我底层封装
说起JMX大家肯定都不陌生,JMX的出现让开发自检测程序出现可能,其提供了大量检测线程 、GC、内存的方式,从而提高了 Java 语言自己的管理监测能力。可以帮助我们定位以下问题: OOM 内存泄露 线程死锁 锁争用(Lock Contention) Java 进程消耗 CPU 过高
实际应用
目前我们可以使用JDK自带的JConsole、VisualVm等,有兴趣可自己查下,在实际服务器部署的时候为了方便提供JMX监控,我们选择自己开启(当然port这种必须要运维来监管的),以下就是在spring boot下使用内置tomat开启的方式之一,直接上代码。
package com.ecej.nove.autoconfigure.jmx;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.DependsOn;
import org.springframework.jmx.support.ConnectorServerFactoryBean;
import org.springframework.remoting.rmi.RmiRegistryFactoryBean;
/**
* JMX监控
*
* @author QIANG
*
*/
@Configuration
public class JmxAutoConfiguration {
private Logger LOGGER = LoggerFactory.getLogger(JmxAutoConfiguration.class);
@Value("${jmx.rmi.host:localhost}")
private String rmiHost;
@Value("${jmx.rmi.port:9999}")
private Integer rmiPort;
@Bean
public RmiRegistryFactoryBean rmiRegistry() {
final RmiRegistryFactoryBean rmiRegistryFactoryBean = new RmiRegistryFactoryBean();
rmiRegistryFactoryBean.setPort(rmiPort);
rmiRegistryFactoryBean.setAlwaysCreate(true);
LOGGER.info("RmiRegistryFactoryBean create success !!");
return rmiRegistryFactoryBean;
}
@Bean
@DependsOn("rmiRegistry")
public ConnectorServerFactoryBean connectorServerFactoryBean() throws Exception {
final ConnectorServerFactoryBean connectorServerFactoryBean = new ConnectorServerFactoryBean();
connectorServerFactoryBean.setObjectName("connector:name=rmi");
connectorServerFactoryBean.setServiceUrl(
String.format("service:jmx:rmi://%s:%s/jndi/rmi://%s:%s/jmxrmi", rmiHost, rmiPort, rmiHost, rmiPort));
LOGGER.info("ConnectorServerFactoryBean create success !!");
return connectorServerFactoryBean;
}
}
复制代码
如此的简单
后记
最近发现,对于线上应用出现TimeOut 、链接异常、服务请求过慢等问题时,基础开发人员貌似没有解决问题的思路。其实应该马上导出ThreadDump,因为从这就可以分析出太多道道了。链接JMX监控查看内存、cpu等状态信息,不能拍脑袋在那傻猜啊。所以这也是为什么这个月主导开发服务链监控的原因了。为了使基础开发能够学会定位解决应用出现的问题,准备忙完写一个根据ThreadDump进行分析的详细案例。
关注公众号,将获得最新文章推送