用jmap和jps查看对象数量

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

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

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

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

C:\Users\wj>jps
13556 org.eclipse.equinox.launcher_1.3.0.v20130327-1440.jar
9804 Jps
6788 Bootstrap

C:\Users\wj>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内核设计剖析》

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

目录
相关文章
|
7月前
|
监控 Java Android开发
使用JDK自带的jmap和jhat监控处于运行状态的Java进程
使用JDK自带的jmap和jhat监控处于运行状态的Java进程
72 0
|
10月前
|
Linux Shell Perl
|
算法 Java
为什么设置-Xmx4g但是java进程内存占用达到8g?
为什么设置-Xmx4g但是java进程内存占用达到8g?
1616 0
为什么设置-Xmx4g但是java进程内存占用达到8g?
|
10月前
|
Java
JVM命令-jcmd
1. jcmd -l 列出当前虚拟机的java进程 2.jcmd 进程ID help 列出当前java进程 能使用的jvm指令。这些指令可通过名字就知道是做什么的
96 0
JVM命令-jcmd
|
SQL 算法 安全
五、JDK命令行工具jps、jstat、jmap、jstack、jhat、jinfo
一、jps,查看虚拟机进程的命令 参数说明 -q:只输出进程 ID -m:输出传入 main 方法的参数 -l:输出完全的包名,应用主类名,jar的完全路径名
155 0
使用 jconsole 命令观察线程
当我们使用多线程编程时,我们可以使用 jconsole 来观察线程的状况。下面我将带领大家如何找到 jconsole 命令
使用 jconsole 命令观察线程
|
存储 缓存 Java
JVM--JVM运行时数据区域详解
Java虚拟机在执行Java程序的过程中会把它所管理的内存划分为若干个不同的数据区域。这些区域有各自的用途,以及创建和销毁的时间,有的区域随着虚拟机进程的启动而一直存在,有些区域则是依赖用户线程的启动和结束而建立和销毁。根据《Java虚拟机规范》的规定,Java虚拟机所管理的内存将会包括以下几个运行时数据区域,如图
66 0
JVM--JVM运行时数据区域详解
|
运维 监控 Kubernetes
JVM 输出 GC 日志导致 JVM 卡住
JVM 输出 GC 日志导致 JVM 卡住
JVM 输出 GC 日志导致 JVM 卡住
|
Java
180724-统计JVM进程中线程数两种方式小记
/proc 目录以可读文本文件形式输出,提供现有进程和系统硬件相关的信息如 CPU、中断、内存、磁盘等等
517 0
180724-统计JVM进程中线程数两种方式小记
Java GC 各个变量含义 和 jstat 命令的使用
Java GC 各个变量含义 和 jstat 命令的使用
Java GC 各个变量含义 和 jstat 命令的使用