1. /tmp/hsperfdata_$USER目录

$USER是启动JAVA进程的用户,这里保存的所有用户启动的JAVA进程。

这些都JAVA进程的PID,里面存放的是JVM进程信息。你所用的jsp、jstack、jmap这些工具都会读取这个目录中对应PID的文件获取连接信息。
有时候你会发现这样的错误

这种情况是你使用的是一个JAVA的线程号而不是一个进程号。因为jstack、jps、jmap这些工具都是使用进程号的。
如果你提供了一个根本不存在的进程号呢?它会告诉你无此进程。

这种情况是你使用的是一个JAVA的线程号而不是一个进程号。因为jstack、jps、jmap这些工具都是使用进程号的。
如果你提供了一个根本不存在的进程号呢?它会告诉你无此进程。

2. 如何查找消耗资源的代码

通过top命令获取消耗资源最大的PID号

通过top –p PID –H来查看指定进程中最消耗资源的线程

把线程ID转换为16进制

printf '0x%x\n' PID

查找代码

如果同一个JAVA进程中有多个占用CPU资源多的线程,那么你就把线程号保存到一个文件中,一行一个号。然后运行下面的命令.
找到线程号,转换成十六进制保存到文件里

保存堆栈信息到文件

查找,写一个循环进程查找

while read LINE; do grep $LINE /tmp/stock.txt ; done < /tmp/threadNum.txt

字段中第一个引号字段就是JAVA线程的名字。由于我这里其实只是展示一下操作过程实际上并没有消耗CPU高的线程,你会看到比较少的信息,如果真的有消耗CPU高的线程,这里会有很多同名的Java线程名称。也不能说是名称完全一样只是主名称相同后面还是有区分的。

3. 堆栈信息说明

prio=N 表示线程的优先级别
os_prio=N 表示线程的操作系统优先级别
tid= 表示线程ID
nid= 表示操作系统影视的线程ID,非常关键,你在top –H –p PID 查看的数字转换为十六进制就是这个

状态 说明
New 线程对象刚刚创建时的状态,此时不可执行
Runnable 表示线程具备所有运行条件,在队列中等待CPU调度
Running 正在运行
Wait on condition 该线程在等待某个条件发生,发生后就可以运行,但具体什么条件需要进一步查看。最常见的就是线程在等待网络的读写,比如网络数据没有准备好,线程处于等待状态,一旦数据准备好线程会被重新激活。
Waiting for monitor entry和In Object.wait()

Monitor是JAVA中实现线程互斥与协调的手段,可以看成对象或者class的锁。每个对象都有,也仅有一个monitor。每个Monitor在某个时刻只能被一个线程拥有,该线程叫做Active Thread,而其他线程叫做“Waiting Tread”,分别在2个队列中“Entry Set”和“Wait Set”里面。在前者队列的线程状态时“Waiting for monitor entry”,在后者队列的线程状态是“in Object.wait()”

Wating on monitor entry:正在等待锁
In Object.wait():获取锁以后又执行了obj.wait()放弃锁

4. 关于“Unable to open socket file: target process not responding or HotSpot VM not loaded”问题

遇到这个问题可能有几个原因:

  1. 运行该命令的用户账号和启动指定进程的用户账号不一致。也就是PID  145784这个进程是通过其他账号启动的,而不是当前你用的账号
  2. /tmp/hsperfdata_$USER这个目录里的内容被清理,这里放的就是启动进程的进程号,由于是临时目录有可能Linux系统定期清理导致进程号文件没有了,所以会打印堆栈信息失败。因为jps和jstack等工具会读取这个目录里面指定进程号的PID文件获取连接信息。
  3. 确保你使用的命令的JDK版本和运行JAVA程序的JDK版本一致。

其实通过第二条就知道为什么第一条存在,因为不同用户会有不同目录,你用root账号虽然权限大,但是它会读取/tmp/hsperfdata_root目录,而你需要打印堆栈的程序是用其他账号启动的,所以用root会报错。
切换账号后打印成功

查找占用资源高的JAVA代码的更多相关文章

  1. Windows下找到JVM占用资源高的线程

    与linux下top命令直接显示进程下线程资源占用不同,Windows下默认任务管理器只能显示出进程的资源占用,jconsle等工具也只能显示出java进程资源占用,无法显示出进程能具体线程的资源占用 ...

  2. SQL SERVER 占用资源高的SQL语句

    --SQL SERVER 占用资源高的SQL语句: --查询占用cpu高的前 50 个 SQL 语句 SELECT total_cpu_time,[total_physical_Reads], tot ...

  3. 编写高质量java代码151个建议

    http://blog.csdn.net/aishangyutian12/article/details/52699938 第一章  Java开发中通用的方法和准则 建议1:不要在常量和变量中出现易混 ...

  4. 利用jstack命令定位占用cpu高的java线程及具体错误代码信息

    1.先用top查询某进程的线程CPU占用情况,定位到cpu占用高的进程pid 2.根据pid定位具体的线程top -p PID -H ,找出占用cpu最大的pid,此处占用cpu比较平均,我们随便选择 ...

  5. Linux中查找最耗性能的JAVA代码

    在这里总结一下查找Linux.Java环境下最耗CPU性能的代码段的方法.基本上原理就是使用top命令查看最耗cpu的进程和线程(子进程).使用jstack把java线程堆栈给dump下来.然后,在堆 ...

  6. 高质量JAVA代码编写规范

    1. Java 命名约定 除了以下几个特例之外,命名时应始终采用完整的英文描述符.此外,一般应采用小写字母,但类名.接口名以及任何非初始单词的第一个字母要大写. 1.1 一般概念 * 尽量使用完整的英 ...

  7. Linux中查找最耗CPU的Java代码问题

    第一步: 查看消耗CPU最高的进程PID [lolaage@web2 tomcat-ns]$ top top - 13:23:32 up 42 days, 19:11,  3 users,  load ...

  8. 查找占用CPU高线程

    1.根据进程号查看线程 ps -mp pid -o THREAD,tid,time 2 把tid值转成16进制 printf "%x\n" tid 3.根据上面获取到的16进制数据 ...

  9. 编写高质量JAVA代码之让接口的职责保持单一

    上述标题读者朋友应该也注意到了是让接口的职责保持单一,而不是实现者单一. 设计模式六大原则之单一原则: 定义 不要存在多于一个导致类变更的原因.**通俗的说,即一个类只负责一项职责. 下面以一个电话模 ...

随机推荐

  1. C# 串口操作系列(4) -- 协议篇,文本协议数据解析

    C# 串口操作系列(4) -- 协议篇,文本协议数据解析 标签: c#uiobjectstringbyte 2010-06-09 01:50 19739人阅读 评论(26) 收藏 举报  分类: 通讯 ...

  2. Flex布局—语法篇

    网页布局(layout)是CSS的一个重点应用. 布局的传统解决方案,基于盒状模型,依赖 display属性 + position属性 + float属性.它对于那些特殊布局非常不方便,比如,垂直居中 ...

  3. go语言基础之range

    在go语言中,遍历数据或切片时可以用range,range会产生两个值,分别是数据的索引与值: package main import "fmt" func main() { x ...

  4. nginx + springboot 配置

    1.spring boot 访问地址http://localhost:13000/test/hello 2.配置nginx.conf文件 upstream my_ngix { server local ...

  5. java课程之团队开发冲刺阶段1.2

    一.总结昨天进度 1.三个任务都已经实现 2.使用时间:四个小时左右 二.遇到的困难 1.对Android原生的侧拉任务栏不了解,导致使用的时候出现了一部分问题 三.今天任务规划 1.对之前的程序重新 ...

  6. [微信小程序]在应用地图时,如何设置满屏(高度)

    微信小程序在做地图功能时 用常规的办法height:100%:来设置高度来占满屏幕是不行的 它不会生效 应该改用单位vh 例如 height:100vh 这样就可以是地图占满整个屏幕高度

  7. Django 简单的使用

    1.创建一个名字为 two 的项目 并 进入项目 2.创建一个 app 3.更改语言和时间 4,注册APP 5.模板创建和设置 设置模板查找的路径 6,然后我们开始设置 路由映射 主项目映射 然后我们 ...

  8. js-day03-事件响应和练习题

    DOM事件编程 事件驱动编程:所谓事件驱动,简单地说就是你点什么按钮(即产生什么事件),电脑执行什么操作(即调用什么函数).当然事件不仅限于用户的操作. 当对象处于某种状态时,可以发出一个消息通知,然 ...

  9. LinkedBlockingQueue 注记

    近期看一个音频传输代码时,对方采用了LinkedBlockingQueue为生产者.消费者模式,来支撑读写线程. 个人感觉非常不错,因此也对这种方式进行总结,并梳理了一个基本的功能框架备用.主要两点: ...

  10. C#的几种文件操作方法

    创建或覆盖文件 需求:如果文件不存在,创建之,如果存在,覆盖之. 1,可能有问题的方法 using (FileStream fs = File.OpenWrite(@"d:\work\1.t ...