JAVA 服务器CPU过高问题

 
 
windows下CPU过高的处理方式:
 
    1、当程序发现CPU过高的情况时,可以使用Windows系统的Process Explorer工具来找到CPU高消耗的线程,所以需要在Windows机器上面搭建好服务器的测试环境,尽量模拟出线上CPU飙升的情况;
    2、模拟好环境后,通过任务管理器,在进程一栏中找到Java程序的进程号;
    3、下载Process Explorer工具:
 
    4、打开工具后,根据刚才的进程号找到进程;
    5、然后右键-->Properties,再选择Threads选项卡,点进CPU排序,可以找到消耗CPU最多的那个线程;
    6、使用科学计算器,将十进制的线程号转成十六进制,比如493620-->78834;
    7、到此已经拿到了可能出问题的进程号和线程号,接下来使用jvm内置的命令来导出Java的堆栈信息:
    jstack -l <进程号> > <导出目录+文件名>
    8、打开导出的堆栈信息,并全文搜索刚刚拿到的十六进制的线程号,就可以找到出问题的代码具体位置了。
 
 
linux下CPU过高的处理方式:
 
    1、netstat -lnapt|grep 端口|wc -l 获取请求连接数
    2、获取进程ID并 top 
        ps -ef|grep user_center 获取进程ID
        top -p pid
    3、ps -mp pid -o time,THREAD,tid|sort  查看该进程PID下线程使用cpu,时间情况
    4、把线程TID转换成16进制 printf “%x\n” tid
    5、jstack查看进程信息 jstack -pid |grep tid的16进制 
    6、根据线程得知,垃圾回收线程阻塞,接下来查看jmap显示Java堆详细信息jmap -heap pid
    查看Heap配置 NewSize只有1.25M 导致新生代(Eden和Old Generation消耗殆尽,)
 
    解决方案:设置heap的大小;Heap Size的设置不宜太小,也不宜太大。若设置太小程序的响应速度会变慢了,因为GC占用了更多的时间,而应用分配到的执行时间较少。太大也会造成空间的浪费,而且也会影响其他程序的正常运行。Heap Size 最大最好不要超过可用物理内存的80%。建议将-Xms和-Xmx选项设置为相同,而-Xmn为1/4的-Xmx值。在resin容器中配置jvm 参数
 
 
 
 
 
 
 
 
 
 
 
posted @ 2020-12-21 23:00  dos_hello_world  阅读(450)  评论(0)    收藏  举报