我的编程空间,编程开发者的网络收藏夹
学习永远不晚

如何使用JMX监控Tomcat

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

如何使用JMX监控Tomcat

这篇文章主要介绍“如何使用JMX监控Tomcat”,在日常操作中,相信很多人在如何使用JMX监控Tomcat问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”如何使用JMX监控Tomcat”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

示例代码

String jmxURL = "service:jmx:rmi:///jndi/rmi://192.168.10.93:8999/jmxrmi";JMXServiceURL serviceURL = new JMXServiceURL(jmxURL);Map map = new HashMap();// 用户名密码,在jmxremote.password文件中查看String[] credentials = new String[] { "monitorRole", "tomcat" };map.put("jmx.remote.credentials", credentials);JMXConnector connector = JMXConnectorFactory.connect(serviceURL, map);MBeanServerConnection mbsc = connector.getMBeanServerConnection();// 端口最好是动态取得ObjectName threadObjName = new ObjectName("Catalina:type=ThreadPool,name=http-8080");MBeanInfo mbInfo = mbsc.getMBeanInfo(threadObjName);// tomcat的线程数对应的属性值String attrName = "currentThreadCount";MBeanAttributeInfo[] mbAttributes = mbInfo.getAttributes();System.out.println("currentThreadCount:" + mbsc.getAttribute(threadObjName, attrName));

完整的示例代码文件

import java.lang.management.MemoryUsage;import java.text.SimpleDateFormat;import java.util.Date;import java.util.Formatter;import java.util.HashMap;import java.util.Iterator;import java.util.Map;import java.util.Set;import javax.management.MBeanAttributeInfo;import javax.management.MBeanInfo;import javax.management.MBeanServerConnection;import javax.management.ObjectInstance;import javax.management.ObjectName;import javax.management.openmbean.CompositeDataSupport;import javax.management.remote.JMXConnector;import javax.management.remote.JMXConnectorFactory;import javax.management.remote.JMXServiceURL;public class JMXTest {        public static void main(String[] args) {        try {            String jmxURL = "service:jmx:rmi:///jndi/rmi://127.0.0.1:8999/jmxrmi";            JMXServiceURL serviceURL = new JMXServiceURL(jmxURL);            Map map = new HashMap();            String[] credentials = new String[] { "monitorRole", "tomcat" };            map.put("jmx.remote.credentials", credentials);            JMXConnector connector = JMXConnectorFactory.connect(serviceURL,                    map);            MBeanServerConnection mbsc = connector.getMBeanServerConnection();            // 端口最好是动态取得            ObjectName threadObjName = new ObjectName(                    "Catalina:type=ThreadPool,name=http-8080");            MBeanInfo mbInfo = mbsc.getMBeanInfo(threadObjName);            String attrName = "currentThreadCount";// tomcat的线程数对应的属性值            MBeanAttributeInfo[] mbAttributes = mbInfo.getAttributes();            System.out.println("currentThreadCount:"                    + mbsc.getAttribute(threadObjName, attrName));            // heap            for (int j = 0; j < mbsc.getDomains().length; j++) {                System.out.println("###########" + mbsc.getDomains()[j]);            }            Set MBeanset = mbsc.queryMBeans(null, null);            System.out.println("MBeanset.size() : " + MBeanset.size());            Iterator MBeansetIterator = MBeanset.iterator();            while (MBeansetIterator.hasNext()) {                ObjectInstance objectInstance = (ObjectInstance) MBeansetIterator                        .next();                ObjectName objectName = objectInstance.getObjectName();                String canonicalName = objectName.getCanonicalName();                System.out.println("canonicalName : " + canonicalName);                if (canonicalName                        .equals("Catalina:host=localhost,type=Cluster")) {                    // Get details of cluster MBeans                    System.out.println("Cluster MBeans Details:");                    System.out                            .println("=========================================");                    // getMBeansDetails(canonicalName);                    String canonicalKeyPropList = objectName                            .getCanonicalKeyPropertyListString();                }            }            // ------------------------- system ----------------------            ObjectName runtimeObjName = new ObjectName("java.lang:type=Runtime");            System.out.println("厂商:"                    + (String) mbsc.getAttribute(runtimeObjName, "VmVendor"));            System.out.println("程序:"                    + (String) mbsc.getAttribute(runtimeObjName, "VmName"));            System.out.println("版本:"                    + (String) mbsc.getAttribute(runtimeObjName, "VmVersion"));            Date starttime = new Date((Long) mbsc.getAttribute(runtimeObjName,                    "StartTime"));            SimpleDateFormat df = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");            System.out.println("启动时间:" + df.format(starttime));            Long timespan = (Long) mbsc.getAttribute(runtimeObjName, "Uptime");            System.out.println("连续工作时间:" + JMXTest.formatTimeSpan(timespan));            // ------------------------ JVM -------------------------            // 堆使用率            ObjectName heapObjName = new ObjectName("java.lang:type=Memory");            MemoryUsage heapMemoryUsage = MemoryUsage                    .from((CompositeDataSupport) mbsc.getAttribute(heapObjName,                            "HeapMemoryUsage"));            long maxMemory = heapMemoryUsage.getMax();// 堆最大            long commitMemory = heapMemoryUsage.getCommitted();// 堆当前分配            long usedMemory = heapMemoryUsage.getUsed();            System.out.println("heap:" + (double) usedMemory * 100                    / commitMemory + "%");// 堆使用率            MemoryUsage nonheapMemoryUsage = MemoryUsage                    .from((CompositeDataSupport) mbsc.getAttribute(heapObjName,                            "NonHeapMemoryUsage"));            long noncommitMemory = nonheapMemoryUsage.getCommitted();            long nonusedMemory = heapMemoryUsage.getUsed();            System.out.println("nonheap:" + (double) nonusedMemory * 100                    / noncommitMemory + "%");            ObjectName permObjName = new ObjectName(                    "java.lang:type=MemoryPool,name=Perm Gen");            MemoryUsage permGenUsage = MemoryUsage                    .from((CompositeDataSupport) mbsc.getAttribute(permObjName,                            "Usage"));            long committed = permGenUsage.getCommitted();// 持久堆大小            long used = heapMemoryUsage.getUsed();//            System.out.println("perm gen:" + (double) used * 100 / committed                    + "%");// 持久堆使用率            // -------------------- Session ---------------            ObjectName managerObjName = new ObjectName(                    "Catalina:type=Manager,*");            Set<ObjectName> s = mbsc.queryNames(managerObjName, null);            for (ObjectName obj : s) {                System.out.println("应用名:" + obj.getKeyProperty("path"));                ObjectName objname = new ObjectName(obj.getCanonicalName());                System.out.println("最大会话数:"                        + mbsc.getAttribute(objname, "maxActiveSessions"));                System.out.println("会话数:"                        + mbsc.getAttribute(objname, "activeSessions"));                System.out.println("活动会话数:"                        + mbsc.getAttribute(objname, "sessionCounter"));            }            // ----------------- Thread Pool ----------------            ObjectName threadpoolObjName = new ObjectName(                    "Catalina:type=ThreadPool,*");            Set<ObjectName> s2 = mbsc.queryNames(threadpoolObjName, null);            for (ObjectName obj : s2) {                System.out.println("端口名:" + obj.getKeyProperty("name"));                ObjectName objname = new ObjectName(obj.getCanonicalName());                System.out.println("最大线程数:"                        + mbsc.getAttribute(objname, "maxThreads"));                System.out.println("当前线程数:"                        + mbsc.getAttribute(objname, "currentThreadCount"));                System.out.println("繁忙线程数:"                        + mbsc.getAttribute(objname, "currentThreadsBusy"));            }        } catch (Exception e) {            e.printStackTrace();        }    }    public static String formatTimeSpan(long span) {        long minseconds = span % 1000;        span = span / 1000;        long seconds = span % 60;        span = span / 60;        long mins = span % 60;        span = span / 60;        long hours = span % 24;        span = span / 24;        long days = span;        return (new Formatter()).format("%1$d天 %2$02d:%3$02d:%4$02d.%5$03d",                days, hours, mins, seconds, minseconds).toString();    }}

到此,关于“如何使用JMX监控Tomcat”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注编程网网站,小编会继续努力为大家带来更多实用的文章!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

如何使用JMX监控Tomcat

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

如何使用JMX监控Tomcat

这篇文章主要介绍“如何使用JMX监控Tomcat”,在日常操作中,相信很多人在如何使用JMX监控Tomcat问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”如何使用JMX监控Tomcat”的疑惑有所帮助!接下来
2023-07-05

如何使用JMX监控应用程序内、外部的状况

这篇文章主要介绍如何使用JMX监控应用程序内、外部的状况,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!Java管理API (JMX)对管理WebLogic服务器而言是必需的。通过这个API,你可以在应用程序服务器里搜
2023-06-03

Java中psi-probe如何监控Tomcat和应用

这篇文章主要介绍了Java中psi-probe如何监控Tomcat和应用,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。psi-probe这也是一个综合性的监控项目,可监控单个
2023-06-02

怎么用zabbix监控tomcat

这篇文章主要为大家展示了“怎么用zabbix监控tomcat”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“怎么用zabbix监控tomcat”这篇文章吧。代理端: java-gateway服务t
2023-06-04

怎么实现Hikari连接池使用SpringBoot配置JMX监控

这篇文章主要介绍“怎么实现Hikari连接池使用SpringBoot配置JMX监控”,在日常操作中,相信很多人在怎么实现Hikari连接池使用SpringBoot配置JMX监控问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希
2023-06-20

JMX 实践:使用 Java 监控和管理的真实案例

Java 监控和管理:JMX 实践指南
JMX 实践:使用 Java 监控和管理的真实案例
2024-02-19

SpringBoot如何使用prometheus监控

这篇文章主要介绍SpringBoot如何使用prometheus监控,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!1.关于PrometheusPrometheus是一个根据应用的metrics来进行监控的开源工具。相
2023-06-14

Hikari连接池使用SpringBoot配置JMX监控的方法是什么

本文小编为大家详细介绍“Hikari连接池使用SpringBoot配置JMX监控的方法是什么”,内容详细,步骤清晰,细节处理妥当,希望这篇“Hikari连接池使用SpringBoot配置JMX监控的方法是什么”文章能帮助大家解决疑惑,下面跟
2023-07-06

linux监控软件如何使用

这篇文章主要讲解了“linux监控软件如何使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“linux监控软件如何使用”吧!linux监控软件有:1、Monit,用于程序和服务监测;2、Ne
2023-06-22

如何使用VBS监控CPU的使用率

小编给大家分享一下如何使用VBS监控CPU的使用率,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!---------------------------------
2023-06-08

Linux监控工具glances如何使用

本篇文章为大家展示了Linux监控工具glances如何使用,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。Linux下如何使用glances?glances是一个基于python语言开发,可以为li
2023-06-28

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录