原文链接:http://blog.csdn.net/chendc201/article/details/22905511

在Java多线程程序运行时,多数情况下我们不知道到底发生了什么,只有出了错误的日志的时候,我们才知道原来代码中有死锁。撇开代码检查工具,我们先讨论一下利用VisualVM监控,分析我们的多线程的运行情况。

AD:51CTO学院:IT精品课程在线看!

在Java多线程程序运行时,多数情况下我们不知道到底发生了什么,只有出了错误的日志的时候,我们才知道原来代码中有死锁。撇开代码检查工具,我们先讨论一下利用VisualVM监控,分析我们的多线程的运行情况。(注:实践本文内容的JDK的版本需要1.6.07以上)

什么是VisualVM

VisualVM是JDK的一个集成的分析工具,自从JDK 6 Update 7以后已经作为Sun的JDK的一部分。

VisualVM可以做的:监控应用程序的性能和内存占用情况、监控应用程序的线程、进行线程转储(Thread Dump)或堆转储(Heap Dump)、跟踪内存泄漏、监控垃圾回收器、执行内存和CPU分析,保存快照以便脱机分析应用程序;同时它还支持在MBeans上进行浏览和操作。尽管 VisualVM自身要在JDK6以上的运行,但是JDK1.4以上版本的程序它都能被它监控。

在JDK1.6.07以上的版本中:到$JAVA_HOME/bin,点击jvisualvm.exe图标就可以启动VisualVM;当然也可以点击这里获取官方的最新版本,支持:英文,中文,日文。

VisualVM功能集成较多,我们这里只讨论它对象线程的监控分析。

VisualVM监控线程

当我们运行VisualVM的时候,可以在应用程序》本地中看到VisualVM和eclipse的运行程序,然后我们启动eclipse中的一个线程:com.longtask.thread.TestVisualVm,可以看到在菜单中多了一个该线程的显示。点击右边的 线程 菜单,可以看到线程运行的跟踪情况。

点击 thread dump,可以生成该线程的运行情况的tdump文件,通过thread dump提供的相关信息,我们可以看到线程在什么地方被阻塞了以及线程的其他状态。

把日志另存为文件,到Thread Dump Analyzer的主页点击图标下载TDA,然后用TDA打开刚才VisualVM保存的 thread dump文件,查看相关的分析结果。

我们也可以用VisualVM来监控远程java线程的运行情况。

远程监控:启动RMI服务

1:新建一个jstatd.all.policy文件,在里面添加以下内容来保证jstatd服务启动的时候不报异常:

  1. grant codebase "file:${java.home}/../lib/tools.jar" {
  2. permission java.security.AllPermission;
  3. };

2:netstat -ano | grep -i 1099 查看1099端口是否被占用了,如果被占用,则需要选择其他端口来启动jstatd服务

3:如果端口被占用,用以下方式启动jstatd服务:

  1. rmiregistry 2020 & jstatd -J-Djava.security.policy=jstatd.all.policy -p 2020

更多jstatd的文档请参考sun公司的官方文档 这里

远程监控Jboos服务

1:修改JDK下面的jmx的配置文件:

切换至$JAVA_HOME所在目录/jre/lib/management下,

I:将jmxremote.access、jmxremote.password.template权限调整为读写:

  1. grant codebase "file:${java.home}/../lib/tools.jar" {
  2. permission java.security.AllPermission;
  3. };

II:vi jmxremote.password去掉

# monitorRole QED

# controlRole R&D

的#号

2:在Jboss的启动文件中添加以下信息:

  1. JAVA_OPTS="-Dcom.sun.management.jmxremote.port=2899 \
  2. -Dcom.sun.management.jmxremote.ssl=false \
  3. -Dcom.sun.management.jmxremote.authenticate=false \
  4. -Djava.rmi.server.hostname=10.212.20.9  其他配置"

3:检查启动情况:

netstat -a | grep -i 2899 查看端口占有情况

如果2899端口被其他程序占用,在jboss配置文件中调整端口-Dcom.sun.management.jmxremote.port=****

而后在VisualVM中就添加远程连接,选择jmx方式,就可以监控jboss的运行情况了。

转载于:https://www.cnblogs.com/lichmama/p/5741063.html

(转载)Java多线程的监控分析工具(VisualVM)相关推荐

  1. Java自带的多线程监控分析工具(VisualVM)

    转自: http://www.udpwork.com/item/1105.html 在java多线程程序运行时,多数情况下我们不知道到底发生了什么,只有出了错误的日志的时候,我们才知道原来代码中有死锁 ...

  2. java visualvm 内存_【Java线程与内存分析工具】VisualVM与MAT简明教程

    前言 本文将简要介绍Java线程与内存分析工具VisualVM和MAT的使用,进一步的学习可参考官网或工具帮助(例如MAT:Help -> Welcome -> Tutorials),并在 ...

  3. 阿里开源性能测试神器,性能监控分析工具Arthas

    Arthas(阿尔萨斯)是Alibaba开源的Java诊断性能监控分析工具,它不需要做任何的参数配置,就可以直观的获取各种维度的性能数据.通过阅读官网的介绍,可以看到,当我们遇到以下类似问题而束手无策 ...

  4. java超线程_超线程多核心下Java多线程编程技术分析

    在学习编程的过程中,我觉得不止要获得课本的知识,更多的是通过学习技术知识提高解决问题的能力,这样我们才能走在最前方,本文主要讲述超线程多核心下Java多线程编程技术分析,更多Java专业知识,广州疯狂 ...

  5. [转载]明天的数字营销分析工具2

    上一篇文章:[转载]明天的数字营销分析工具1 工具三:HeapAnalytics HeapAnalytics是另外一个很具有前瞻性的解决方案.这个工具非常符合我在上集中说的"去技术化&quo ...

  6. 一款好用的Linux系统服务器性能监控分析工具介绍

    软件性能测试过程中经常要对服务器性能指标(比如CPU.内存.磁盘IO及网络IO等等)进行监控以分析出软件在此服务器上的性能瓶颈以便进行后续的服务器调优及软件性能优化.下面为大家介绍一款小编认为比较好用 ...

  7. java多线程执行任务(工具升级版)

    java多线程执行任务(工具升级版) 昨天写的java多线程执行任务(工具)但是不能符合顺序执行计划的场景,下面升级一下原工具 java多线程执行任务(工具) 更新java多线程执行任务(工具再升级版 ...

  8. Java几款性能分析工具的对比

    在给客户的应用程序维护的过程中,我注意到在高负载下的一些性能问题.理论上,增加对应用程序的负载会使性能等比率的下降.然而,我认为性能下降的比率远远高于负载的增加.我也发现,性能可以通过改变应用程序的逻 ...

  9. java开发调试定位分析工具大全

    Java是一种非常强大的编程语言,自问世以来就广受欢迎.作为现今十分流行的移动平台--Android的核心语言,它大大促进了移动通信行业的发展.因此可以肯定,随着Android平台的不断扩张,Java ...

  10. Java Mission Control-Java 性能分析工具

    引言 本文为 Java 性能分析工具系列文章第三篇,这里将介绍如何使用 Java 任务控制器 Java Mission Control 深入分析 Java 应用程序的性能,为程序开发人员在使用 Jav ...

最新文章

  1. Button的使用(十三):设置可见性
  2. 最新综述:基于Transformer的NLP预训练模型已经发展到何种程度?
  3. MySQL分区:range(范围)list(in)columns(多字段)hash(散列)key(非数值型的hash)复合(hash key)
  4. Linux命令之ifconfig
  5. 使用Kubeadm搭建Kubernetes(1.12.2)集群
  6. matlab作业5答案,《matlab作业题答案》.doc
  7. CKEditor 4 编辑器已与 Vue.js 集成
  8. WinEdt 打开***.bib文件时 error reading
  9. Zabbix(四):高级应用之--宏、网络发现测试实例
  10. opc服务器的时间怎么修改,OPC服务器是否允许在其逻辑中使用源时间戳?(Is OPC server allowed to use source timestamp in its logic?)...
  11. 基于STM32的ESP8266天气时钟(2)--------MCU获取天气数据
  12. 部分选中文件的快捷键
  13. 深入浅出LDA(1)
  14. 【报告分享】2022年移动市场报告-App Annie(附下载)
  15. 安卓版微信数据库导出
  16. Python 爬虫二 requests模块
  17. 在 Nuxt.js 和 Vue.js 项目中引入第三方字体或艺术字
  18. 使用期望等待一次性事件
  19. java导入visio文件
  20. 小觅智能亮相2019中国IT产业校企合作大会

热门文章

  1. 闭环检测python_激光SLAM | 基于深度图的闭环检测
  2. 多目标优化问题和遗传算法学习
  3. GO 计算所有并发任务的总时间 WaitGroup
  4. django 1366, “Incorrect string value: for column ‘‘ at row
  5. Linux ubuntu基本知识
  6. kubernetes endpoints是什么
  7. mysql处理emoji表情_mysql支持emoji表情存取的解决方案
  8. nodejs连接postgresql_PostgreSQL 使用 node-postgres 在 node.js 中的应用
  9. html基礎之渐变属性(斑马线)
  10. LNMPS PHP 团队开发 需要用到的相关工具(2017年11月更新)