给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 进行预定。感谢各位朋友。
=========================