iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >如何使用JMX监控Tomcat
  • 628
分享到

如何使用JMX监控Tomcat

2023-07-05 17:07:25 628人浏览 独家记忆
摘要

这篇文章主要介绍“如何使用JMX监控Tomcat”,在日常操作中,相信很多人在如何使用JMX监控Tomcat问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”如何使用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”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注编程网网站,小编会继续努力为大家带来更多实用的文章!

--结束END--

本文标题: 如何使用JMX监控Tomcat

本文链接: https://www.lsjlt.com/news/353476.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

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

下载Word文档
猜你喜欢
  • 如何使用JMX监控Tomcat
    这篇文章主要介绍“如何使用JMX监控Tomcat”,在日常操作中,相信很多人在如何使用JMX监控Tomcat问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”如何使用JMX监控Tomcat”的疑惑有所帮助!接下来...
    99+
    2023-07-05
  • 如何使用JMX监控应用程序内、外部的状况
    这篇文章主要介绍如何使用JMX监控应用程序内、外部的状况,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!Java管理API (JMX)对管理WebLogic服务器而言是必需的。通过这个API,你可以在应用程序服务器里搜...
    99+
    2023-06-03
  • Hikari连接池使用SpringBoot配置JMX监控实现
    Hikari是Spring Boot默认的数据库连接池。区别于C3P0直接通过连接池对象获取各项状态指标,Hikari需要通过JMX来获取。Demo如下,采用Spring Boot集...
    99+
    2024-04-02
  • 怎么用zabbix监控tomcat
    这篇文章主要为大家展示了“怎么用zabbix监控tomcat”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“怎么用zabbix监控tomcat”这篇文章吧。代理端: java-gatew...
    99+
    2023-06-04
  • Java中psi-probe如何监控Tomcat和应用
    这篇文章主要介绍了Java中psi-probe如何监控Tomcat和应用,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。psi-probe这也是一个综合性的监控项目,可监控单个...
    99+
    2023-06-02
  • JMX 实践:使用 Java 监控和管理的真实案例
    Java 管理扩展 (JMX) 是一种强大的框架,用于监控和管理 Java 应用程序。本文提供了实际案例,展示了如何使用 JMX 监视和管理各种性能指标,包括内存使用、线程使用和应用程序状态。 简介 JMX 是一种用于监测和管理 Jav...
    99+
    2024-02-19
    JMX Java 监控 管理 MBean 性能
  • 怎么实现Hikari连接池使用SpringBoot配置JMX监控
    这篇文章主要介绍“怎么实现Hikari连接池使用SpringBoot配置JMX监控”,在日常操作中,相信很多人在怎么实现Hikari连接池使用SpringBoot配置JMX监控问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希...
    99+
    2023-06-20
  • JMX 技术:Java 应用监控与管理的利刃
    ...
    99+
    2024-04-02
  • 如何使用zabbix监控mongod
    如何使用zabbix监控mongod,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。1 被监控端写mongodb.sh注意:里面的路径和你的...
    99+
    2024-04-02
  • 如何使用zabbix监控MySQL
    这篇文章将为大家详细讲解有关如何使用zabbix监控MySQL,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。        &nb...
    99+
    2024-04-02
  • SpringBoot如何使用prometheus监控
    这篇文章主要介绍SpringBoot如何使用prometheus监控,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!1.关于PrometheusPrometheus是一个根据应用的metrics来进行监控的开源工具。相...
    99+
    2023-06-14
  • Hikari连接池使用SpringBoot配置JMX监控的方法是什么
    本文小编为大家详细介绍“Hikari连接池使用SpringBoot配置JMX监控的方法是什么”,内容详细,步骤清晰,细节处理妥当,希望这篇“Hikari连接池使用SpringBoot配置JMX监控的方法是什么”文章能帮助大家解决疑惑,下面跟...
    99+
    2023-07-06
  • linux监控软件如何使用
    这篇文章主要讲解了“linux监控软件如何使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“linux监控软件如何使用”吧!linux监控软件有:1、Monit,用于程序和服务监测;2、Ne...
    99+
    2023-06-22
  • 教你如何通过JConsoler监控Tomcat的JVM内存
    目录1.监控Tomcat的方式2.Java自带的监控命令 3.Tomcat故障案例4.配置Tomcat JMX监控5.使用Jsconsole连接JMX查看监控数据通过JConsole...
    99+
    2024-04-02
  • Java JMX 揭秘:监控、管理和优化你的 Java 应用
    ...
    99+
    2024-04-02
  • 如何使用VBS监控CPU的使用率
    小编给大家分享一下如何使用VBS监控CPU的使用率,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!'----------------------------...
    99+
    2023-06-08
  • nagios中如何使用check_mysql监控mysql
    nagios中如何使用check_mysql监控mysql,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。 nagios监控mysql服务器:...
    99+
    2024-04-02
  • Netdata如何监控CPU使用情况
    要监控CPU使用情况,您可以使用Netdata的Web界面来查看系统的实时CPU使用率。以下是通过Netdata监控CPU使用情况的...
    99+
    2024-04-02
  • Linux监控工具glances如何使用
    本篇文章为大家展示了Linux监控工具glances如何使用,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。Linux下如何使用glances?glances是一个基于python语言开发,可以为li...
    99+
    2023-06-28
  • 如何使用zabbix监控vmware exsi主机
    今天就跟大家聊聊有关如何使用zabbix监控vmware exsi主机,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。进入虚拟化vcenter中,用浏览器登录(客户端没找到地方设置),...
    99+
    2023-06-15
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作