百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程网 > 正文

JMX监控原理与使用详解(手把手教你JMX)

yuyutoo 2025-05-23 21:12 2 浏览 0 评论

JMX经常用于监控Java程序的基本信息和运行情况,本篇重点详解JMX的技术架构,以及如何使用@mikechen

本篇已收于mikechen原创超30万字《阿里架构师进阶专题合集》里面。

什么是JMX

JMX(Java Management Extensions),含义为Java管理扩展的缩写,是一个为应用程序植入管理功能的框架,提供了一种简单的、标准的监控和管理资源的方式。

JMX 的应用场景

JMX有以下典型的应用场景:

  • 监控应用程序的运行状态和相关统计信息;
  • 修改应用程序的配置(无需重启);
  • 状态变化或出错时通知处理。

举个例子,我们可以通过jconsole监控应用程序的堆内存使用量、线程数、类数,查看某些配置信息,甚至可以动态地修改配置。

下图是使用Jconsle通过JMX查看Java程序的运行信息:

JMX最常见的场景是监控Java程序的基本信息和运行情况,任何Java程序都可以开启JMX,然后使用JConsole或VisualVM进行预览。

JMX 的技术架构

从图中我们可以看到,JMX的结构一共分为三层:

1、基础层:主要是MBean,被管理的资源

MBean分为如下四种:

2、适配层:主要是提供对资源的注册和管理。

Agent层 用来管理相应的资源,并且为远端用户提供访问的接口。

Agent层主要定义了各种服务以及通信模型,该层的核心是 MBeanServer,所有的MBean都要向它注册,才能被管理。

注册在MBeanServer上的MBean并不直接和远程应用程序进行通信,他们通过 协议适配器(Adapter) 和 连接器(Connector) 进行通信。

通常Agent由一个MBeanServer和多个系统服务组成。

3、接入层:提供远程访问的入口。

怎么使用JMX

下面我们就简单的使用jmx来实现配置bean属性的动态修改,动态修改的意思就是在不重启服务器的情况下,实现配置属性的变更。

第一步:提供管理信息

1) 首先定义一个MBean接口,接口的命名规范为以具体的实现类为前缀(这个规范很重要)

//接口要以MBean结尾
public interface HelloMBean {
    String getName();
    void setName(String name);
}

2)定义一个实现类,实现上面的接口

//实现类跟接口在同一个包中,且名字不包含MBean
public class Hello implements HelloMBean {
    private String name;
    @Override
    public String getName() {
        System.out.println("Hello.getName");
        return name;
    }
    @Override
    public void setName(String name) {
        this.name = name;
        System.out.println("Hello.setName");
    }
}

第二步:使用jconsole连接

jconsole是jdk自带工具,在配置了jdk环境之后,我们只需要在cmd命令行中输入jconsole即可。

如下图所示:

然后我们就可以在这里来进行Name属性的修改。

第三步:控制打印结果

本篇已收于mikechen原创超30万字《阿里架构师进阶专题合集》里面。

相关推荐

Linux内核网络设备驱动

1.接收数据包过程概述介绍数据包收包过程,有助于我们了解Linux内核网络设备在数据收包过程中的位置,下面从宏观的角度介绍数据包从被网卡接收到进入socket接收队列的整个过程:加载网卡驱动,初...

「技术」一文带你掌握Linux字符设备架构

一、Linux设备分类Linux系统为了管理方便,将设备分成三种基本类型:...

「技术干货」一文搞懂Linux内核调试方法(二)

上篇回顾:一文Linux内核调试方法(一)...

Pytorch学习Day 5: 神经网络基础(nn.Module)学习课程

学习目标理解PyTorch中nn.Module类的作用和核心功能。掌握如何使用nn.Linear构建简单的单层神经网络。学会访问和打印神经网络的参数。通过代码实践加深对PyTorch神...

内存问题探微

这篇文章是我在公司TechDay上分享的内容的文字实录版,本来不想写这么一篇冗长的文章,因为有不少的同学问是否能写一篇相关的文字版,本来没有的也就有了。说起来这是我第二次在TechDay上做的...

阿里架构师的5年经验总结:盘点数据仓库常用的4大数据工具平台

数据仓库是解决方案,真正落地的时候,还要依托于工具平台。...

软考系统架构师2021_备考说明---软考高级之系统架构师_备考笔记

第一轮一个半月.这些是考试内容.这个通过率全国,只有百分之10左右..挺难的....

从 Java 程序员到架构师:技术进阶与能力跃迁的完整路径(深度版)

#程序员如何进阶为架构师?#从Java程序员到架构师:技术进阶与能力跃迁的完整路径(深度版)...

大厂架构师被A1逼疯:我20年经验不如A1五分钟生成的方案

程序员末日?AI竟包办八成代码!前端真的凉了?...

立志成为架构师的你请收下——架构设计的三种思维

软件架构的几个误区1.架构的目标即灵活性灵活性越好的架构越能适应未来变化的需要,但不是架构设计的目标,一味追求容易陷入另外一个坑,造成性能的损失和资源的浪费。2.一套成熟的开源框架就是架构框...

系统架构师之——软件开发方法

不管你是开发人员,还是互联网行业人员,基本上经常看到各种各样的软件相关的图,如什么架构图什么设计图什么模式图甘特图等。很多时候总是傻傻分不清。对此,我们很有必要对系统开发基础知识有认知。对于一名程序员...

系统分析师和系统架构师的区别是什么?

软考高级包括系统分析师、信息系统项目管理师、网络规划设计师、系统架构设计师和系统规划与管理师,其中,系统分析师和系统架构师这两个科目是大家很容易搞混淆的,因为都属于软考,所以他们的报考时间、报考条件都...

软件开发 “四高”的详细分析——高扩展

高并发架构的黄金法则:用“分治异步”玩转每秒10万+请求弹性架构:像搭乐高一样扩展你的系统杰夫·贝索斯曾说:“架构不是设计出来的,而是演化出来的。”高并发系统的核心在于...

复习七天通过软考高级系统架构师

前言软考复习的方式可以分为两种:报班和自学。首先晒一下成绩,开心的一批,虽然考的不是很好!!每科满分75,需要同时都>=45分才算合格。...

软件开发 “四高”的详细分析,即高并发、高性能、高扩展、高可用

高并发(HighConcurrency)是互联网分布式系统架构设计中必须考虑的因素之一,它通常是指,通过设计保证系统能够同时并行处理很多请求。高并发相关常用的一些指标有响应时间(ResponseT...

取消回复欢迎 发表评论: