java程序之cpu,内存消耗分析

本文介绍了一种在程序运行过程中遇到连接超时和请求连接变慢的问题解决方法。通过一系列步骤,如检查连接数、分析线程CPU使用情况、识别垃圾回收线程阻塞,最终定位到Heap配置不足导致的问题,并给出了调整HeapSize的解决方案。
摘要由CSDN通过智能技术生成

程序启动运行一段时间后,发现请求连接变慢,增加,导致连接超时

1、netstat -lnapt|grep 端口|wc -l 获取请求连接数

这里的连接数是修复后的连接数;当时连接数爆到6000多;

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 参数

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值