用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内核设计剖析》

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

目录
相关文章
|
Arthas 运维 监控
定位频繁创建对象导致内存溢出风险的思路
定位频繁创建对象导致内存溢出风险的思路
443 1
Springboot接口同时支持GET和POST请求
Springboot接口同时支持GET和POST请求
1292 0
|
Java 中间件 数据库连接
分库分表的4种方案
分库分表的4种方案
1720 0
|
存储 缓存 自然语言处理
Elasticesearch内存详解
Elasticesearch内存详解总结文章
4802 0
Elasticesearch内存详解
|
3月前
|
SQL 算法 关系型数据库
什么是 ‘小表驱动大表’ 原则?如何实现 JOIN顺序优化?(图解+秒懂+史上最全)
什么是 ‘小表驱动大表’ 原则?如何实现 JOIN顺序优化?(图解+秒懂+史上最全)
什么是 ‘小表驱动大表’ 原则?如何实现 JOIN顺序优化?(图解+秒懂+史上最全)
|
11月前
|
运维 网络架构
CIDR 与 VLSM:了解它们的工作原理
CIDR 与 VLSM:了解它们的工作原理
442 4
执行脚本出现 standard in must be a tty
出现该提示是因为你执行的脚本的时候并不是在没有对应用户的环境变量,应该在脚本中加入su - username,来加载环境变量。
616 0
|
SQL 存储 Java
实时计算 Flink版产品使用合集之怎么配置日志的输出格式和文件大小
实时计算Flink版作为一种强大的流处理和批处理统一的计算框架,广泛应用于各种需要实时数据处理和分析的场景。实时计算Flink版通常结合SQL接口、DataStream API、以及与上下游数据源和存储系统的丰富连接器,提供了一套全面的解决方案,以应对各种实时计算需求。其低延迟、高吞吐、容错性强的特点,使其成为众多企业和组织实时数据处理首选的技术平台。以下是实时计算Flink版的一些典型使用合集。
238 1
|
消息中间件 负载均衡 Java
|
网络协议 SDN 数据安全/隐私保护