• windows下揪出java程序占用cpu很高的线程 并找到问题代码


    今天开启个项目后登陆后没过多久后发现,页面慢的很,而且电脑声音响的很,打开任务管理器看了下发现cpu占用高达100%

    系统是win2010

    所以在windows平台上要找出到底是哪个线程占用的cpu还不那么容易,linux用top就简单多了

    最后的解决方法:

    1.找到java进程对应的pid。

    找pid的方法是:打开任务管理器,找到详情中的java.exe 找到其pID

     

    2.然后把java进程导出快照。直接运行命令。

    jstack -l 3468> c:/3468.stack

    我这里是指定把java所有的信息导出到e盘的3468.stack的文件里。
    3.在windows下只能查看进程的cpu占用率,要查看线程的cpu占用率要借助其他的工具,我这里用的是微软提供的 Process Explorer v15.3

    下载地址http://technet.microsoft.com/en-us/sysinternals/bb896653.aspx

    https://pan.baidu.com/s/1hQkdsiv5jJCP6trcqZHc6A  百度提取码 2z5h

    下载完后解压运行

    右键点击需要查看的进程---properties

     

     

    4.然后选择 Threads 选项卡,找到占用cpu的线程的tid,比如我这里是 12464的线程

    5.把pid转换成16进制,我这里直接用系统自带的计算器转换,置于为什么要转换,是因为先前用jstack导出的信息里面线程对应的tid是16进制的。

     

    最后得到的线程pid的16进制的值为 306b

    6.在 e盘的3468.stack文件中查找 306b

     然后在代码里面找到server.java

    注释掉这段代码后

    cpu就会到了正常

    原文:https://blog.csdn.net/hexin373/article/details/8846919

  • 相关阅读:
    f12 接口自动刷新页面 来不及看接口信息 前端有没有传值
    order by 分组报错 shop 有三个字段 根据author 选出最大的price
    mybatis 动态sql
    正则 只有英文或者数字 长度6位以上 数字或者英文全部一样
    sql :1 :2
    前端Json数据,后台String接收,如何解析
    Json数据格式化
    LeetCode63. 不同路径 II
    LeetCode62. 不同路径
    LeetCode746. 使用最小花费爬楼梯
  • 原文地址:https://www.cnblogs.com/liyiren/p/10565575.html
Copyright © 2020-2023  润新知