我是靠谱客的博主 平常楼房,最近开发中收集的这篇文章主要介绍用jmap和jps查看对象数量,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

给https://github.com/sea-boat/net-reactor添加bufferpool,使用直接内存。

功能需求是启动时初始化一定量的buffer,每建立一个连接都分配一个buffer作为读写缓冲,管理连接时将buffer放回pool中,而当pool的buffer不够用时则额外创建buffer并放到pool中。

为了方便观察,首先只初始化包含1个buffer的池,再将JVM包含的内存对象导出到文件中。

C:Userswj>jps
13556 org.eclipse.equinox.launcher_1.3.0.v20130327-1440.jar
9804 Jps
6788 Bootstrap
C:Userswj>jmap -histo:live 6788 > d:/dump.txt

挑出buffer相关的两个对象,如下,此时一共有8个DirectByteBuffer和2个DirectByteBuffer$Deallocator

8
512
java.nio.DirectByteBuffer
2
64
java.nio.DirectByteBuffer$Deallocator

接着客户端发起10个socket连接,此时分别为18个和12个

18
1152
java.nio.DirectByteBuffer
12
384
java.nio.DirectByteBuffer$Deallocator

继续增加5个socket连接,此时分别为28个和22个

 23
1472
java.nio.DirectByteBuffer
17
544
java.nio.DirectByteBuffer$Deallocator

关闭掉5个socket连接,此时为23个和17个

 23
1472
java.nio.DirectByteBuffer
17
544
java.nio.DirectByteBuffer$Deallocator

再次增加10个连接,此时为28个和22个

 28
1792
java.nio.DirectByteBuffer
22
704
java.nio.DirectByteBuffer$Deallocator

结论:符合功能需求。

========广告时间========

鄙人的新书《Tomcat内核设计剖析》已经在京东销售了,有需要的朋友可以到 https://item.jd.com/12185360.html 进行预定。感谢各位朋友。

为什么写《Tomcat内核设计剖析》

=========================

最后

以上就是平常楼房为你收集整理的用jmap和jps查看对象数量的全部内容,希望文章能够帮你解决用jmap和jps查看对象数量所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(73)

评论列表共有 0 条评论

立即
投稿
返回
顶部