ICode9

精准搜索请尝试: 精确搜索
首页 > 系统相关> 文章详细

Java 线程究竟占用多少内存

2021-05-30 10:58:28  阅读:368  来源: 互联网

标签:reserved XX 线程 内存 committed Java


”更新:“


JVM 并没有主动按照线程数量分配 “threads ’ 1MB”,这个错误来自 NMT 报告。Java 8 “committed memory”会自动置为 “reserved memory”。参见 <https://bugs.openjdk.java.net/browse/JDK-8191369>


”committed memory“大小由堆栈深度决定,感谢 [Thomas Stuefe][1] 的提醒。


---


[1]:https://dzone.com/users/3720329/tstuefe.html


在 Java 应用总内存消耗中,线程使用的内存占很大一部分。根据应用具体特点,比如 CPU 受限或者 IO 受限,可以选择对应技术限制新建的线程数量。对于 IO 受限应用可以创建线程池,由线程处理 IO 操作,比如在阻塞或等待状态从数据库读取数据、发送 HTTP 请求等。如果是计算密集型应用,可以使用像 Netty 这样的 HTTP 服务器,线程数量少、节省内存。接下来通过具体示例展示一个新线程需要消耗多少内存。


线程内存包括栈帧、局部变量、方法参数等,线程大小默认如下(KB):


```shell
$ java -XX:+PrintFlagsFinal -version | grep ThreadStackSize
    intx CompilerThreadStackSize    = 1024  {pd product} {default}
    intx ThreadStackSize            = 1024  {pd product} {default}
    intx VMThreadStackSize          = 1024  {pd product} {default}
```


1. Java 8 线程内存消耗


```shell
$ java -XX:+UnlockDiagnosticVMOptions -XX:NativeMemoryTracking=summary /
-XX:+PrintNMTStatistics -version
openjdk version "1.8.0_212"
OpenJDK Runtime Environment (AdoptOpenJDK)(build 1.8.0_212-b03)
OpenJDK 64-Bit Server VM (AdoptOpenJDK)(build 25.212-b03, mixed mode)
Native Memory Tracking:
Total: reserved=6621614KB, committed=545166KB
-                 Java Heap (reserved=5079040KB, committed=317440KB)
                           (mmap: reserved=5079040KB, committed=317440KB)
-                     Class (reserved=1066074KB, committed=13786KB)
                           (classes #345)
                           (malloc=9306KB #126)
                           (mmap: reserved=1056768KB, committed=4480KB)
-                    Thread (reserved=19553KB, committed=19553KB)
                           (thread #19)
                           (stack: reserved=19472KB, committed=19472KB)
                           (malloc=59KB #105)
                           (arena=22KB #34)
```


可以看到两种类型的内存:


  • “Reserved:” 由操作系统承诺的可用内存大小。但尚未分配,JVM 无法访问

  • ”Committed:“ 已被 JVM 分配,可访问


在“Thread”部分可以看到,‘reserved’ 和 ‘committed’ 大小相同,接近于“线程数 ‘ 1MB”。这时因为 JVM 一开始就尽可能地为线程分配内存。


2. Java 11 线程内存消耗


```shell
$ java -XX:+UnlockDiagnosticVMOptions -XX:NativeMemoryTracking=summary /
-XX:+PrintNMTStatistics -version
openjdk version "11.0.2" 2019-01-15
OpenJDK Runtime Environment AdoptOpenJDK (build 11.0.2+9)
OpenJDK 64-Bit Server VM AdoptOpenJDK (build 11.0.2+9, mixed mode)
Native Memory Tracking:
Total: reserved=6643041KB, committed=397465KB
-                 Java Heap (reserved=5079040KB, committed=317440KB)
                           (mmap: reserved=5079040KB, committed=317440KB)
-                     Class (reserved=1056864KB, committed=4576KB)
                           (classes #426)
                           (  instance classes #364, array classes #62)
                           (malloc=96KB #455)
                           (mmap: reserved=1056768KB, committed=4480KB)
                           (  Metadata:   )
                           (    reserved=8192KB, committed=4096KB)
                           (    used=2849KB)
                           (    free=1247KB)
                           (    waste=0KB =0,00%)
                           (  Class space:)
                           (    reserved=1048576KB, committed=384KB)
                           (    used=270KB)
                           (    free=114KB)
                           (    waste=0KB =0,00%)
-                    Thread (reserved=15461KB, committed=613KB)
                           (thread #15)
                           (stack: reserved=15392KB, committed=544KB)
                           (malloc=52KB #84)
                           (arena=18KB #28)
```


从上面地结果可以注意到,Java 11 节省了很多内存,不会在线程创建时主动分配 ‘Reserved Memory’。当然,这只是 ’java -version‘ 命令的执行结果。如果试着使用 Java 11,会发现内存分配有显著改进。



标签:reserved,XX,线程,内存,committed,Java
来源: https://blog.51cto.com/u_15127686/2832714

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有