「java如何监控进程」java程序监控
今天给各位分享java如何监控进程的知识,其中也会对java程序监控进行解释,如果能碰巧解决你现在面临的问题,别忘了关注本站,现在开始吧!
本文目录一览:
如何监控java进程
JDK本身提供了很多方便的JVM性能调优监控工具,除了集成式的VisualVM和jConsole外,还有jps、jstack、jmap、jhat、jstat等小巧的工具,本博客希望能起抛砖引玉之用,让大家能开始对JVM性能调优的常用工具有所了解。
现实企业级Java开发中,有时候我们会碰到下面这些问题:
OutOfMemoryError,内存不足
内存泄露
线程死锁
锁争用(Lock Contention)
Java进程消耗CPU过高
......
这些问题在日常开发中可能被很多人忽视(比如有的人遇到上面的问题只是重启服务器或者调大内存,而不会深究问题根源),但能够理解并解决这些问题是Java程序员进阶的必备要求
A、 jps(Java Virtual Machine Process Status Tool)
jps主要用来输出JVM中运行的进程状态信息
B、 jstack
jstack主要用来查看某个Java进程内的线程堆栈信息。
C、 jmap(Memory Map)和jhat(java Heap Analysis Tool)
jmap用来查看堆内存使用状况,一般结合jhat使用。
D、jstat(JVM统计监测工具)
用java监视系统进程的两个解决方案
用第一个java虚拟机启动另一个虚拟机 并用第一个虚拟机的java程序去测试另一个虚拟机上java程序运行时的内存 CPU资源占用情况
解决问题的限制和条件
》两个虚拟机运行在同台Windows_X 机上
》只需要知道第二个虚拟机上运行程序时 第二个虚拟机的内存 CPU使用情况
》目的是 测试不同的程序在同个虚拟机上资源使用差别
解决问题的关键
第一 如何启动另一虚拟机运行测试的java程序
第二 如何用第一个虚拟机里的java程序 监视另一个虚拟机与其相关进程的运行情况
解决办法
一 使用java io中的函数(命令试过没问题 程序请按下面提示完成)
使用java io中的函数
Runtime getRuntime() exec( 系统命令 )
这里我给一个带命令参数的例子
Runtime r=Runtime getRuntime();Process p=null;String cmd[]={ 命令 参数 };try{ p=r exec(cmd);}catch(Exception e){System out println( error executing: +cmd[ ]);}
这里要使用到的系统命令有几个
path/java file//用第二个jvm(path为第二个jre/bin/地址)运行java程序filetasklist log txt//将当前系统进程写以 任务管理器 的格式()写入//log txt文件中 关于tasklist使用细节 如查询某个进程ID的信息//可以使用命令 tasklist /? 进行查询
这两步均在第一个虚拟机完成 简单!!!
二 常规方法使用JNI
这里我给一套解决方案 网上有很多相关代码 自己去找找
lishixinzhi/Article/program/Java/hx/201311/26640
Java监控一个进程的执行状态
应用程序很高兴对所有这些活动一无所知。它只知道自己的虚拟地址空间。但是,如果当前在主存中的页面集(称为 驻留集)少于实际要使用的页面集(称为 工作集),应用程序的性能很快就会显著降低。(不幸的是,本文中您将看到,我们要讨论的工具常常交换使用这两个术语,尽管它们指的是完全不同的事物。) Task Manager 和 PerfMon 我们首先考察两种最常见的工具:Task Manager 和 PerfMon。这两个工具都随 Windows 一起提供,因此由此起步比较容易。 Task Manager Task Manager 是一种非常见的 Windows 进程监控程序。您可以通过熟悉的 Ctrl-Alt-Delete 组合键来启动它,或者右击任务栏。Processes 选项卡显示了最详细的信息,如图 2 所示。 图 2. Task Manager 进程选项卡 图 2 中显示的列已经通过选择 View -- Select Columns 作了调整。有些列标题非常含糊,但可以在 Task Manager 帮助中找到各列的定义。和进程内存使用情况关系最密切的计数器包括: Mem Usage(内存使用):在线帮助将其称为进程的工作集(尽管很多人称之为驻留集)——当前在主存中的页面集。但是这个数值包含能够和其他进程共享的页面,因此要注意避免重复计算。比方说,如果要计算共享同一个 DLL 的两个进程的总内存占用情况,不能简单地把“内存使用”值相加。 Peak Mem Usage(内存使用高峰值):进程启动以来 Mem Usage(内存使用)字段的最大值。 Page Faults(页面错误):进程启动以来要访问的页面不在主存中的总次数。 VM Size(虚拟内存大小):联机帮助将其称为“分配给进程私有虚拟内存总数。”更确切地说,这是进程所 提交的内存。如果进程保留内存而没有提交,那么该值就与总地址空间的大小有很大的差别。 虽然 Windows 文档将 Mem Usage(内存使用)称为工作集,但在该上下文中,它实际上指的是很多人所说的驻留集(resident set),明白这一点很重要。您可以在 Memory Management Reference 术语表(请参阅 参考资料)中找到这些术语的定义。 工作集 更通常的含义指的是一个逻辑概念,即在某一点上为了避免分页操作,进程需要驻留在内存中的那些页面。 PerfMon 随 Windows 一起提供的另一种 Microsoft 工具是 PerfMon,它监控各种各样的计数器,从打印队列到电话。PerfMon 通常在系统路径中,因此可以在命令行中输入 perfmon 来启动它。这个工具的优点是以图形化的方式显示计数器,很容易看到计数器随时间的变化情况。 请在 PerfMon 窗口上方的工具栏中单击 + 按钮,这样会打开一个对话框让您选择要监控的计数器,如图 3a 所示。计数器按照 性能对象分成不同的类别。与内存使用关系最密切的两个类是 Memory 和 Process。选中计数器然后单击 Explain 按钮,就可以看到计数器的定义。说明出现在主对话框下方弹出的单独的窗口中。
java如何监控进程的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于java程序监控、java如何监控进程的信息别忘了在本站进行查找喔。