java 溯本求源之基础(十八)之Monitoring--jmc

1.JMC概述

        JMC全称Java Mission Control,集成了多个功能强大的组件,其中最核心的两部分是管理控制台和Java Flight Recorder。管理控制台允许开发者实时监控应用的运行状态,捕捉各种性能指标;而Java Flight Recorder则提供了一种高效的数据记录方式,可以在不显著影响系统性能的情况下,记录下应用的详细运行数据。除此之外,JMC还支持插件扩展,使得它可以更灵活地满足特定的监控需求。

        JMC不仅是一款功能全面的工具,还特别注重用户体验和操作便捷性。它的用户界面简洁直观,即使是不太熟悉深度性能调优的开发者也能轻松上手。此外,JMC的灵活性和扩展性使其能够轻松集成到各种Java开发和测试环境中,无论是在开发初期的性能评估,还是在生产环境中的故障诊断,都能发挥重要作用。

2.配置
2.1配置JMC

        在首次启动JMC后,可能需要进行一些基本配置,以优化其性能监控功能:

  • 工作空间选择:用户可以指定一个工作空间,JMC将在此处存储用户设置和临时数据。
  • 内存配置:为了保证JMC运行时的性能,可适当调整JVM参数,例如增加最大堆内存设置。
  • 安全设置:如果需要远程监控Java应用,需配置JMC的安全参数,包括远程连接的认证方式。远程连接时需要增加点参数

-Dcom.sun.management.jmxremote

-Dcom.sun.management.jmxremote.port=<PORT>

-Dcom.sun.management.jmxremote.authenticate=false

-Dcom.sun.management.jmxremote.ssl=false

-Djava.rmi.server.hostname=ip

-Dcom.sun.management.jmxremote.rmi.port=<PORT>     如果未指定,JMX服务可能会随机选择一个端口用于RMI通信,这可能会被防火墙阻止。显式设置RMI端口可以帮助确保连接稳定。

2.2 主要功能
2.2.1管理控制台

        JMC的管理控制台提供了丰富的功能,帮助开发者监控应用的实时性能数据:

  • 实时性能监控:展示CPU使用率、内存使用情况、线程状态等关键性能指标。
  • 自定义仪表盘:用户可以根据需要自定义监控仪表盘,关注对特定项目重要的指标。

2.2.2Java Flight Recorder

        Java Flight Recorder (JFR) 是一个强大的数据收集框架,它可以在对应用性能影响极小的情况下,记录详细的运行时信息:

  • 事件录制:JFR可以记录各种事件,包括Java级别的事件和JVM内部事件,如垃圾收集、线程启动等。
  • 数据分析:JFR收集的数据可以在JMC中进行详细分析,帮助开发者定位性能瓶颈或异常行为。

        这里其实我们在介绍java -XX的属性的时候也提到过,那就是针对jfr的参数

2.2.3插件系统

        JMC支持通过插件扩展其功能,这意味着开发者可以安装第三方插件或开发自定义插件来满足特定监控需求:

  • 插件安装:用户可以通过JMC的插件管理界面搜索、安装和管理插件。
  • 插件开发:有经验的开发者可以利用JMC提供的API开发专属插件,增强其监控能力。
3.常见应用场景
3.1识别内存泄漏

        内存泄漏是Java应用中常见的问题之一,会导致应用随着时间的推移而变得越来越慢,最终可能出现内存耗尽的情况。使用Java Mission Control可以有效地诊断此类问题:

  1. 启动Java Flight Recorder:对目标应用进行记录,特别关注内存相关的指标,如堆内存使用和垃圾回收活动。
  2. 分析记录数据:在JMC中分析收集到的数据,查找异常的内存使用模式或频繁的垃圾回收行为。
  3. 定位泄漏源:利用JMC提供的详细堆分析工具,识别持有大量内存且生命周期异常的对象。

        当然最常见的还是我们dump出来一个文件,因为对于TOB来说 我们不能直接访问的。

3.2优化应用响应时间

        对于需要快速响应的应用,任何延迟都可能影响用户体验。JMC可以帮助开发者找到导致响应延迟的原因:

  1. 记录应用性能:在Java Flight Recorder中开启对响应时间敏感的事件记录,如线程锁等待和网络I/O操作。
  2. 分析性能瓶颈:使用JMC分析这些事件的记录,识别可能导致延迟的操作或代码段。
  3. 实施优化:根据分析结果调整代码或配置,如优化数据库查询或减少不必要的同步操作。
3.3 调试生产环境中的异常

        在生产环境中直接调试问题通常具有一定的风险,JMC提供了一种低风险的诊断方法:

  1. 远程监控生产应用:配置JMC以安全地连接到生产环境中的Java应用。
  2. 实时数据观察:监控关键性能指标和日志,实时捕捉异常情况。
  3. 问题追踪和分析:一旦发现问题,快速启动记录并在问题发生后进行详细分析,以减少对生产环境的干扰。
4.总结
4.1JMC的主要优势

        Java Mission Control是一款强大的性能监控和诊断工具,专为Java应用设计。它的主要优势包括:

  1. 全面的性能数据:JMC提供详尽的性能监控数据,帮助开发者深入理解应用在运行时的行为。
  2. 实时诊断能力:能够在应用运行过程中实时收集和分析数据,及时发现并解决性能问题。
  3. 低开销的数据收集:Java Flight Recorder提供的数据收集机制对应用性能的影响极小,适合在生产环境中使用。
  4. 易于集成和使用:JMC可以轻松集成到Eclipse等开发环境中,使用方便,用户界面友好。
  5. 扩展性强:支持通过插件扩展功能,可根据具体需求定制监控和分析工具。
4.2 JMC在现代Java开发中的重要性

        在快速迭代和高质量要求的当今软件开发环境中,性能监控和诊断工具的重要性日益凸显。总之,Java Mission Control是每个Java开发者工具箱中的必备工具,它的强大功能和灵活性使其成为提升Java应用性能和稳定性的关键助力。随着技术的不断发展,JMC也将继续演进,为Java社区提供更多的支持。

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

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

相关文章

ELK日志系统的搭建

文章目录 简介软件准备安装JDK下载Elasticsearch软件修改配置信息创建ElasticSearch运行用户、启动服务添加防火墙策略ElasticSearch-Head插件安装 安装Kibana下载软件包修改配置启动服务 安装Logstash安装包下载安装服务配置修改配置pipeline流水线服务配置文件 启动服务 全流…

腾讯云轻量应用服务器和CVM S5服务器有什么区别?

腾讯云轻量应用服务器和CVM云服务器S5有什么不同&#xff1f;性能哪个更好一些&#xff1f;CVM S5云服务器CPU采用2.5GHz主频的Intel Xeon Cascade Lake或者Intel Xeon Cooper Lake处理器&#xff0c;轻量不支持指定CPU&#xff0c;从功能、内网连通性、集群及公网带宽等方面对…

邂逅JavaScript逆向爬虫-------基础语法篇之面向对象

目录 一、概念二、对象的创建和操作2.1 JavaScript创建对象的方式2.2 对象属性操作的控制2.3 理解JavaScript创建对象2.3.1 工厂模式2.3.2 构造函数2.3.3 原型构造函数 三、继承3.1 通过原型链实现继承3.2 借用构造函数实现继承3.3 寄生组合式继承3.3.1 对象的原型式继承3.3.2 …

并发编程之线程通信及Condition的原理分析

1. synchronized中的线程通信 调用wait方法会使线程处于等待状态&#xff0c;直到另一个线程调用notify线程才会唤醒等待中的某个线程&#xff0c;生产者和消费者模型可以很好的使用到该例子。 生产者代码: public class Producer implements Runnable {private Queue<Str…

虚拟现实(VR)的应用场景

虚拟现实&#xff08;VR&#xff09;技术创建和体验三维虚拟世界的计算机仿真技术。用户通过佩戴VR头显等设备&#xff0c;可以完全沉浸在虚拟世界中&#xff0c;并与虚拟世界中的物体进行交互。VR技术具有广泛的应用前景&#xff0c;可以应用于各行各业。以下是一些VR的应用场…

STM32标准库编程与51单片机直接写寄存器的区别和联系

简介&#xff1a; 在学完51单片机之后&#xff0c;我们去学习32的时候&#xff0c;会发现编程的方法有很大的区别&#xff0c;让人非常的不适应&#xff0c;但是通过不断的调用相应外设的库函数之后&#xff0c;你也可以去编程STM32&#xff0c;来实现功能&#xff0c;但是你真…

SQL的基础语句

1、select语句 select colums from table_name 2、条件语句 #查询出查询出用户id为1和3的用户记录 IN 操作符允许我们在 WHERE 子句中规定多个值。 select * from student where id in (1,3) #查询出所有姓王的同学 模糊查询 like 通配符(% 任意多个字符 _单个字符) #下例…

如何使用渐变块创建自定义聊天机器人

如何使用渐变块创建自定义聊天机器人 文章目录 如何使用渐变块创建自定义聊天机器人一、介绍二、参考示例1、一个简单的聊天机器人演示2、将流式传输添加到您的聊天机器人3、喜欢/不喜欢聊天消息4、添加 Markdown、图像、音频或视频 一、介绍 **重要提示&#xff1a;**如果您刚…

软考高级架构师:AI 通俗讲解负载测试、压力测试、强度测试、容量测试和可靠性测试

在软件工程领域&#xff0c;测试是一个确保软件质量和性能的关键步骤。负载测试、压力测试、强度测试、容量测试和可靠性测试都是性能测试的不同类型&#xff0c;它们的目的和方法有所不同。 下面我将通过简单的比喻和解释&#xff0c;帮助您理解这些测试之间的区别。 负载测试…

跳跃游戏 II (贪心, 动态规划)

题目描述(力扣45题) : 给定一个长度为 n 的 0 索引整数数组 nums。初始位置为 nums[0]。 每个元素 nums[i] 表示从索引 i 向前跳转的最大长度。换句话说&#xff0c;如果你在 nums[i] 处&#xff0c;你可以跳转到任意 nums[i j] 处: 0 < j < nums[i] i j < n 返回到…

使用Unity扫描场景内的二维码,使用插件ZXing

使用Unity扫描场景内的二维码&#xff0c;使用插件ZXing 使用Unity扫描场景内的二维码&#xff0c;ZXing可能没有提供场景内扫描的方法&#xff0c;只有调用真实摄像机扫描二维码的方法。 实现的原理是&#xff1a;在摄像机上添加脚本&#xff0c;发射射线&#xff0c;当射线打…

【面试八股总结】Linux系统下的I/O多路复用

参考资料 &#xff1a;小林Coding、阿秀、代码随想录 I/O多路复用是⼀种在单个线程或进程中处理多个输入和输出操作的机制。它允许单个进程同时监视多个文件描述符(通常是套接字)&#xff0c;一旦某个描述符就绪&#xff08;一般是读就绪或者写就绪&#xff09;&#xff0c;能够…

分享三个转换速度快、准确率高的视频转文字工具

想要直接将视频转换成文字&#xff0c;转换工具很重要&#xff01;给大家分享三个转换速度快、准确率高的视频转文字工具&#xff0c;轻松完成转换。 1.网易见外 https://sight.youdao.com/ 网易家的智能转写翻译服务工作站&#xff0c;网页端就可以直接使用&#xff0c;支持视…

Spring Bean依赖注入-Spring入门(二)

1、SpringBean概述 在Spring中&#xff0c;一切Java对象都被视为Bean&#xff0c;用于实现某个具体功能。 Bean的依赖关系注入的过程&#xff0c;也称为Bean的装配过程。 Bean的装配方式有3种&#xff1a; XML配置文件注解Java类 Spring中常用的两种装配方式分别是基于XML的…

Codeforces Round 821 (Div. 2) D2. Zero-One

题目 #include <bits/stdc.h> using namespace std; #define int long long #define pb push_back #define fi first #define se second #define lson p << 1 #define rson p << 1 | 1 const int maxn 1e5 5, inf 1e18, maxm 4e4 5; const int N 1e6;c…

【MySQL】InnoDB与MyISAM存储引擎的区别与选择

存储引擎就是存储数据、建立索引、更新/查询数据等技术的实现方式 。 存储引擎是基于表的&#xff0c;而不是基于库的&#xff0c;所以存储引擎也可被称为表类型。我们可以在创建表的时候&#xff0c;来指定选择的存储引擎&#xff0c;如果没有指定将自动选择默认的存储引擎。…

【工具-PyCharm】

工具-PyCharm ■ PyCharm-简介■ PyCharm-安装■ PyCharm-使用■ 修改主题■ 设置字体■ 代码模板■ 解释器配置■ 文件默认编码■ 快捷键■ 折叠■ 移动■ 注释■ 编辑■ 删除■ 查看■ 缩进■ 替换 ■ PyCharm-简介 官方下载地址 Professional&#xff1a;专业版&#xff0…

python--使用pika库操作rabbitmq实现需求

Author: wencoo Blog&#xff1a;https://wencoo.blog.csdn.net/ Date: 22/04/2024 Email: jianwen056aliyun.com Wechat&#xff1a;wencoo824 QQ&#xff1a;1419440391 Details:文章目录 目录正文 或 背景pika链接mqpika指定消费数量pika自动消费实现pika获取队列任务数量pi…

JavaScript(二)

JavaScript的语法 1.JavaScript的大小写 在JavaScript中&#xff0c;大小写是敏感的&#xff0c;这意味着大小写不同的标识符被视为不同的变量或函数。例如&#xff0c;myVariable 和 myvariable 被视为两个不同的变量。因此&#xff0c;在编写JavaScript代码时&#xff0c;必…

如何在PostgreSQL中创建并使用窗口函数来进行复杂的分析查询?

文章目录 解决方案1. 了解窗口函数的基本概念2. 常用的窗口函数3. 使用示例示例 1&#xff1a;计算每行销售数据的累计销售额示例 2&#xff1a;计算每行销售数据相对于前一行销售额的增长率 结论 PostgreSQL 提供了一套强大的窗口函数&#xff08;Window Functions&#xff09…