JVM内存参数( -Xms -Xmx -Xmn -Xss 直接内存)
jvm 内存 在不同的情况下如何增大 及 PermGen space 相关
-Xms 为jvm启动时的内存 -Xmx 为jvm运行最大内存 -Xss 为jvm每个线程内存大小 -Xmn :设置年轻代大小。 整个堆大小=年轻代大小 + 年老代大小 ,而非整个堆大小=年轻代 大小 + 年老代大小 + 持久代大小
-XX:PermSize=64M JVM初始分配的非堆内存
-XX:MaxPermSize=128M JVM最大允许分配的非堆内存
-XX:MaxDirectMemorySize=10M 最大直接内存
堆和非堆
1,堆就是Java代码可及的内存,是留给开发人员使用的;
2,非堆就是JVM留给自己用的,
方法区、JVM内部处理或优化所需的内存(如JIT编译后的代码缓存)、每个类结构(如运行时常数池、字段和方法数据)以及方法和构造方法的代码都在非堆内存中。
直接内存(Direct Memory)
并不是虚拟机运行时数据区的一部分,也不是Java虚拟机规范中定义的内存区域,也可能导致OutOfMemoryError 异常出现
在JDK 1.4 中新加入了NIO(New Input/Output)类,引入了一种基于通道(Channel)与缓冲区(Buffer)的I/O 方式,
它可以使用Native 函数库直接分配堆外内存,然后通过一个存储在Java 堆里面的DirectByteBuffer 对象作为这块内存的引用进行操作。
这样能在一些场景中显著提高性能,因为避免了在Java 堆和Native 堆中来回复制数据。
优点:
直接内存需要allocateDirect创建,但是它比申请普通的堆内存需要耗费更高的性能。
不过,这部分的数据是在JVM之外的,因此它不会占用应用的内存。
heap ByteBuffer -> -XX:Xmx
1.一种是heap ByteBuffer,该类对象分配在JVM的堆内存里面,直接由Java虚拟机负责垃圾回收,
direct ByteBuffer -> -XX:MaxDirectMemorySize
2.一种是direct ByteBuffer是通过jni在虚拟机外内存中分配的。通过jmap无法查看该快内存的使用情况。只能通过top来看它的内存使用情况