Netty - PooledByteBufAllocator
2024-09-04 09:09:54
堆外内存,
就是非JVM管理的,由os管理的内存,等同于c语言里面的mallco分配的内存
故堆外内存的好处,
1. 不会有GC回收,缓解gc压力
2. 避免一次copy,发生到socket buffer的时候,如果是堆内内存需要copy到堆外一次
问题,
回收是个问题;性能没有heap好,分配和回收的效率都更低
https://www.jianshu.com/p/ce7c6f5cb5f6
https://blog.csdn.net/pentiumchen/article/details/45372625
mark
Netty的池化内存管理方案,可以选择heap或direct
大体思想,
内存大小分级,按需分配
PoolArena 内存管理池
管理一堆chunk list,一个list的chunk数是可变的
chunk由page组成,chunk大小,由pagesize和page个数决定
为了针对小内存分布,subpage,tiny是以16字节为单位,small以512为单位,个数取决于page大小
二叉树组织内存块,便于连续内存分配
一共4094个page,分11层,叶节点一个8K,到第10层,一个节点16k,9层,32k
Netty会用PoolThreadLocalCache来cache buffer,
使用netty池化内存,要注意泄露
https://juejin.im/post/5d903c97e51d457810073dda
最新文章
- python征程1.3(初识python)
- IOS UIView 01-View开始深入 绘制像素到屏幕上
- PHP旧系统基于命名空间重构经验
- java多线程系类:基础篇:10生产者消费者的问题
- 关于servlet的filter
- Android的开发环境的发展演变
- 纵观minecraft 游戏作者的世界观
- ZOJ 1914 Arctic Network (POJ 2349) MST
- Android(java)学习笔记248:ContentProvider使用之虚拟短信
- 转:更改 centos yum 源
- nodejs教程
- Apache HTTP Server 与 Tomcat 的三种连接方式介绍(转)
- AndroidStudio下gradle的入门介绍与使用
- 数据库连接问题之:Caused by: java.sql.SQLException: Connections could not be acquired from the underlying database!
- 理解 docker 容器中的 uid 和 gid
- linux安装OpenCV以及windows安装numpy、cv2等python2.7模块
- Metasploit Framework(6)客户端渗透(上)
- 【BZOJ4919】[Lydsy六月月赛]大根堆
- Leetcode 86
- js代码上的优化