有一个开启了30个线程来消费nsq的程序,内存我给他分配了3g,其中新生代是1g,老年代是2g,新生代的内存会在10s中填满发生垃圾收集,然后不断重复该操作,但是该程序知识消费一些nsq消息然后处理下,之后丢弃,理论上不会那么快把内存填满。我想知道用什么工具能比较容易定位究竟是哪里的程序占用了那么多新生代空间,因为我使用dump工具查看了查看了dump文件发现占比比较大的类型是int[],但我没发现程序中哪用用过int[]。请问各位大神有什么经验可以分享一下?谢谢各位。
有一个开启了30个线程来消费nsq的程序,内存我给他分配了3g,其中新生代是1g,老年代是2g,新生代的内存会在10s中填满发生垃圾收集,然后不断重复该操作,但是该程序知识消费一些nsq消息然后处理下,之后丢弃,理论上不会那么快把内存填满。我想知道用什么工具能比较容易定位究竟是哪里的程序占用了那么多新生代空间,因为我使用dump工具查看了查看了dump文件发现占比比较大的类型是int[],但我没发现程序中哪用用过int[]。请问各位大神有什么经验可以分享一下?谢谢各位。
15 回答8.4k 阅读
8 回答6.2k 阅读
1 回答4k 阅读✓ 已解决
3 回答6k 阅读
3 回答2.2k 阅读✓ 已解决
2 回答3.1k 阅读
2 回答3.8k 阅读
是啥意思,理论上不gc话,该对象还是在堆内存里的。你可以把你的dump的文件导入到MAT里,然后trace下那个int[]就能看到引用路径了