最近看到一个rocketmq的图片,其中有不经过java的heap直接从内存读数据到socket的描述,这用的是jvm的特性吗?
单个JVM进程也能利用机器超大内存
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
1条回答 默认 最新
- yizishou 2017-11-10 04:16关注
这是Java NIO的特性。
通过管道传输数据,而不是通过流,这样可以避免数据在Java堆中的拷贝,提高效率。
这样说吧,你可以将磁盘上的文件看做一个管道,而将网卡看做另外一个管道,通过Java代码直接控制这两个管道接通,之后的数据传输则自发进行。
如果是使用数据流,那么你需要将文件内容读入Java堆,然后将堆中数据写入网卡,数据在Java堆中的进出是消耗时间的。
如果你想关注这方面的东西,可以了解一下这些关键字:零拷贝、Linux管道
解决 无用评论 打赏 举报
悬赏问题
- ¥15 activity升级到flowable工作流act_ge_bytearray的草稿json数据复制到act_de_model 的model_editor_json的脚本
- ¥15 cvi使用CreateThread创建线程时,出现存储空间不足无法处理此命令的错误
- ¥15 求苹果推信imessage批量推信技术
- ¥15 ubuntu 22.04 系统盘空间不足。隐藏的docker空间占用?(相关搜索:移动硬盘|管理系统)
- ¥15 c++ word自动化,为什么可用接口是空的?
- ¥15 Matlab计算100000*100000的矩阵运算问题:
- ¥50 VB6.0如何识别粘连的不规则的数字图片验证码
- ¥16 需要完整的这份订单所有的代码,可以加钱
- ¥30 写一个带界面控制的机房电脑一键开机关机并且实时监控的软件
- ¥15 Stata数据分析请教