-vmargs -Xms128M -Xmx512M -XX:PermSize=64M -XX:MaxPermSize=128M
-vmargs 说明后面是VM的参数,所以后面的其实都是JVM的参数了
-Xms128m JVM初始分配的堆内存
-Xmx512m JVM最大允许分配的堆内存,按需分配
-XX:PermSize=64M JVM初始分配的非堆内存
-XX:MaxPermSize=128M JVM最大允许分配的非堆内存,按需分配
-
weblogic的非堆内存MaxPermSize与系统max locked memory关联
2016-04-26 02:01:37weblogic加载jsp预编译出现内存溢出,OutOfMemoryError: PermGen space java.lang.OutOfMemoryError: PermGen space 一查是MaxPermSize设置的太小了,想调大一点,但同事说系统参数max locked memory=64设置的不够,... -
jvm 堆内存及非堆内存配置
2017-04-01 11:35:00PermSize=64M -XX:MaxPermSize=128M-vmargs 说明后面是VM的参数,所以后面的其实都是JVM的参数了-Xms128m JVM初始分配的堆内存-Xmx512m JVM最大允许分配的堆内存,按需分配-XX:PermSize=64M JVM初始分配的非堆内存-...转载于:https://www.cnblogs.com/suncong/p/6655268.html
-
java统计非堆内存_JVM快速调优手册之一: 内存结构(堆内存和非堆内存)
2021-03-18 01:02:49图为Java虚拟机运行时的数据区:方法区也称”永久代” 、“非堆”, 它用于存储虚拟机加载的类信息、常量、静态变量、是各个线程共享的内存区域。默认最小值为16MB,最大值为64MB(未验证),可以通过-XX:PermSize 和 -...图为Java虚拟机运行时的数据区:
方法区
也称”永久代” 、“非堆”, 它用于存储虚拟机加载的类信息、常量、静态变量、是各个线程共享的内存区域。默认最小值为16MB,最大值为64MB(未验证),可以通过-XX:PermSize 和 -XX:MaxPermSize 参数限制方法区的大小。
运行时常量池:是方法区的一部分,Class文件中除了有类的版本、字段、方法、接口等描述信息外,还有一项信息是常量池,用于存放编译器生成的各种符号引用,这部分内容将在类加载后放到方法区的运行时常量池中。
虚拟机栈
描述的是java 方法执行的内存模型:每个方法被执行的时候 都会创建一个“栈帧”用于存储局部变量表(包括参数)、操作栈、方法出口等信息。每个方法被调用到执行完的过程,就对应着一个栈帧在虚拟机栈中从入栈到出栈的过程。声明周期与线程相同,是线程私有的。
局部变量表存放了编译器可知的各种基本数据类型(boolean、byte、char、short、int、float、long、 double)、对象引用(引用指针,并非对象本身),其中64位长度的long和double类型的数据会占用2个局部变量的空间,其余数据类型只占1 个。局部变量表所需的内存空间在编译期间完成分配,当进入一个方法时,这个方法需要在栈帧中分配多大的局部变量是完全确定的,在运行期间栈帧不会改变局部 变量表的大小空间。
本地方法栈
与虚拟机栈基本类似,区别在于虚拟机栈为虚拟机执行的java方法服务,而本地方法栈则是为Native方法服务。
堆
也叫做java 堆、GC堆,是java虚拟机所管理的内存中最大的一块内存区域,也是被各个线程共享的内存区域,在JVM启动时创建。该内存区域存放了对象实例及数组(所有new的对象)。其大小通过-Xms(最小值)和-Xmx(最大值)参数设置,-Xms为JVM启动时申请的最小内存,-Xmx为JVM可申请的最大内存。在JVM启动时,最大内存会被保留下来。为对象内存而保留的地址空间可以被分成年轻代和老年代。
默认当空余堆内存小于40%时,JVM会增大Heap到-Xmx指定的大小,可通过-XX:MinHeapFreeRation=来指定这个比列;当空余堆内存大于70%时,JVM会减小heap的大小到-Xms指定的大小,可通过XX:MaxHeapFreeRation=来指定这个比列,对于运行系统,为避免在运行时频繁调整Heap的大小,通常-Xms与-Xmx的值设成一样。
Parameter
Default Value
MinHeapFreeRatio
40
MaxHeapFreeRatio
70
-Xms
3670k
-Xmx
64m
注:如果是64位系统,这些值一般需要扩张30%,来容纳在64位系统下变大的对象。
从J2SE 1.2开始,JVM使用分代收集算法,在不同年代的区域里使用不同的算法。堆被划分为新生代和老年代。新生代主要存储新创建的对象和尚未进入老年代的对象。老年代存储经过多次新生代GC(MinorGC)任然存活的对象。
注1:图中的Perm不是堆内存,是永久代注2:图中的Virtaul则是各区域还未被分配的内存,即最大内存-当前分配的内存
新生代:
新生代包括一块eden(伊甸园)和2块survivor(通常又称S0和S1或From和To)。大多数对象都是在eden中初始化。而对于2块survivor来说,总有一块是空的,它会在下一个复制收集过程中作为eden中的活跃对象和另一块survivor的目的地。在对象衰老之前(也就是被复制到tenured之前),它们会在两块survivor区域之间以这样的方式复制。可通过-Xmn参数来指定新生代的大小,也可以通过-XX:SurvivorRation来调整Eden Space及Survivor Space的大小。
老年代:
用于存放经过多次新生代Minor GC依然存活的对象,例如缓存对象,新建的对象也有可能直接进入老年代,主要有两种情况:
大对象,可通过启动参数设置-XX:PretenureSizeThreshold=1024(单位为字节,默认为0)来代表超过多大时就不在新生代分配,而是直接在老年代分配。
大的数组对象,即数组中无引用外部对象。
老年代所占的内存大小为-Xmx对应的值减去-Xmn对应的值。
程序计数器
是最小的一块内存区域,它的作用是当前线程所执行的字节码的行号指示器,在虚拟机的模型里,字节码解释器工作时就是通过改变这个计数器的值来选取下一条需要执行的字节码指令,分支、循环、异常处理、线程恢复等基础功能都需要依赖计数器完成。
-
java 非堆 内存溢出_Tomcat和JBoss加大启动堆和非堆内存,防止内存溢出的方法 | 学步园...
2021-03-14 02:24:46直接上图:JBoss,找到%bin%/run.bat,用记事本打开,找到以下位置,并添加后面那段(即加大堆内存的方法):Tomcat,在%Tomcat%/bin目录下,新建如:run1.bat文件,内容如下:set java_home=C:/j2sdk1.4.2_08startup....直接上图:
JBoss,找到%bin%/run.bat,用记事本打开,找到以下位置,并添加后面那段(即加大堆内存的方法):
Tomcat,
在%Tomcat%/bin目录下,新建如:run1.bat文件,内容如下:
set java_home=C:/j2sdk1.4.2_08
startup.bat -Xms512m -Xmx1024m -XX:MaxPermSize=256m -XX:PermSize=256M
即增加了启动的参数,加大启动内存。
在eclipse上的操作,如图:
对于这4个参数的解释如下:
-Xms128m -Xmx512m -XX:MaxPermSize=64m -XX:PermSize=128M
这四个参数其实都是JVM参数,
-Xms128m JVM初始分配的堆内存-Xmx512m JVM最大允许分配的堆内存,按需分配-XX:PermSize=64M JVM初始分配的非堆内存-XX:MaxPermSize=128M JVM最大允许分配的非堆内存,按需分配
(
关于java内存机制,可参考我的另外一篇博客
)
Xms和Xmx针对的是堆内存,是java代码可及的内存,是给开发人员使用的内存,比如,你把数据库的海量数据都load到内存里超过分配的堆内存,就会暴内存溢出,这个内存溢出就是OutOfMemory,堆溢出。
-Xms128m JVM初始分配的堆内存。如果-Xmx不指定或者指定偏小,应用可能会导致java.lang.OutOfMemory错误,此错误来自JVM,不是Throwable的,无法用try...catch捕捉。
-Xmx512m JVM最大允许分配的堆内存。
-XX:PermSize=64M JVM初始分配的非堆内存,是JVM自己的,不是给开发人员用的,主要是用来存放Class和Meta的信息,Class文件在被Load的时候被放入PermGen space区域,它和存放Instance的Heap堆区域不同。比如,这个往往发生在服务器(tomcat等)加载项目时,项目太大又没设置非堆内存的话,启动就会暴这个错,因为大量class文件load到非堆内存,超过了非堆内存限制,就会暴PermGen
space错误,往往通过设置-XX:PermSize=64M -XX:MaxPermSize=128M解决,增大非堆内存。
-XX:MaxPermSize设置过小会导致java.lang.OutOfMemoryError: PermGen space就是内存益出。
这两种抛的异常是不一样的,堆内存益处是java.lang.OutOfMemory,非堆内存溢出会报java.lang.OutOfMemoryError: PermGen space。
对于tomcat安装版,很多人在\bin\catalina.bat文件的内容,即在里面增加一行代码:set JAVA_OPTS=-Xms512m -Xmx512m
但发现不起作用.即通过windows的服务启动tomcat时,实际的内存还是默认的,修改的设置并没有起作用;而通过\bin\startup.bat启动却是生效的。这是为什么呢?因为在安装过程中,JVM的初始化参数已经写在注册表中了,由于没有修改注册表中相关参数,所以以windows服务方式启动时,修改的并没有生效。而通过\bin\startup.bat启动直接是通过\bin\catalina.bat文件中的配置的。你需要重新加载到系统服务中才生效,或者你手工在注册表中查找修改启动值,加载到服务中的时候参数已经配置好了,自己修改sartup.bat不会改变注册表中的参数设置。
解决方法:修改注册表中的参数,加入JVM初始化内存的参数:HKEY_LOCAL_MACHINE\SOFTWARE\Apache Software Foundation\Tomcat Service Manager\Tomcat5\Parameters\JavaOptions值为-Dcatalina.home="C:\ApacheGroup\Tomcat 5.0"
-Djava.endorsed.dirs="C:\ApacheGroup\Tomcat 5.0\common\endorsed"
-Xrs如加入-Xms512m -Xmx800m
-
JVM快速调优之一:内存结构(堆内存和非堆内存)
2018-11-13 11:22:37永久代” 、“非堆”, 它用于存储虚拟机加载的类信息、常量、静态变量、是各个线程共享的内存区域。默认最小值为16MB,最大值为64MB(未验证),可以通过-XX:PermSize 和 -XX:MaxPermSize 参数限制方法区的大小。 ...图为Java虚拟机运行时的数据区:
1.方法区
也称"永久代” 、“非堆”, 它用于存储虚拟机加载的类信息、常量、静态变量、是各个线程共享的内存区域。默认最小值为16MB,最大值为64MB(未验证),可以通过-XX:PermSize 和 -XX:MaxPermSize 参数限制方法区的大小。
运行时常量池:是方法区的一部分,Class文件中除了有类的版本、字段、方法、接口等描述信息外,还有一项信息是常量池,用于存放编译器生成的各种符号引用,这部分内容将在类加载后放到方法区的运行时常量池中。
2.虚拟机栈
描述的是java 方法执行的内存模型:每个方法被执行的时候 都会创建一个“栈帧”用于存储局部变量表(包括参数)、操作栈、方法出口等信息。每个方法被调用到执行完的过程,就对应着一个栈帧在虚拟机栈中从入栈到出栈的过程。声明周期与线程相同,是线程私有的。
局部变量表存放了编译器可知的各种基本数据类型(boolean、byte、char、short、int、float、long、 double)、对象引用(引用指针,并非对象本身),其中64位长度的long和double类型的数据会占用2个局部变量的空间,其余数据类型只占1 个。局部变量表所需的内存空间在编译期间完成分配,当进入一个方法时,这个方法需要在栈帧中分配多大的局部变量是完全确定的,在运行期间栈帧不会改变局部 变量表的大小空间。
3.本地方法栈
与虚拟机栈基本类似,区别在于虚拟机栈为虚拟机执行的java方法服务,而本地方法栈则是为Native方法服务。
4.堆
也叫做java 堆、GC堆,是java虚拟机所管理的内存中最大的一块内存区域,也是被各个线程共享的内存区域,在JVM启动时创建。该内存区域存放了对象实例及数组(所有new的对象)。其大小通过-Xms(最小值)和-Xmx(最大值)参数设置,-Xms为JVM启动时申请的最小内存,-Xmx为JVM可申请的最大内存。在JVM启动时,最大内存会被保留下来。为对象内存而保留的地址空间可以被分成年轻代和老年代。
默认当空余堆内存小于40%时,JVM会增大Heap到-Xmx指定的大小,可通过-XX:MinHeapFreeRation=来指定这个比列;当空余堆内存大于70%时,JVM会减小heap的大小到-Xms指定的大小,可通过XX:MaxHeapFreeRation=来指定这个比列,对于运行系统,为避免在运行时频繁调整Heap的大小,通常-Xms与-Xmx的值设成一样。
Parameter Default Value MinHeapFreeRatio 40 MaxHeapFreeRatio 70 -Xms 3670k -Xmx 64m 注:如果是64位系统,这些值一般需要扩张30%,来容纳在64位系统下变大的对象。
从J2SE 1.2开始,JVM使用分代收集算法,在不同年代的区域里使用不同的算法。堆被划分为新生代和老年代。新生代主要存储新创建的对象和尚未进入老年代的对象。老年代存储经过多次新生代GC(MinorGC)任然存活的对象。
注1:图中的Perm不是堆内存,是永久代
注2:图中的Virtaul则是各区域还未被分配的内存,即最大内存-当前分配的内存新生代:
新生代包括一块eden(伊甸园)和2块survivor(通常又称S0和S1或From和To)。大多数对象都是在eden中初始化。而对于2块survivor来说,总有一块是空的,它会在下一个复制收集过程中作为eden中的活跃对象和另一块survivor的目的地。在对象衰老之前(也就是被复制到tenured之前),它们会在两块survivor区域之间以这样的方式复制。可通过-Xmn参数来指定新生代的大小,也可以通过-XX:SurvivorRation来调整Eden Space及Survivor Space的大小。老年代:
用于存放经过多次新生代Minor GC依然存活的对象,例如缓存对象,新建的对象也有可能直接进入老年代,主要有两种情况:①.大对象,可通过启动参数设置-XX:PretenureSizeThreshold=1024(单位为字节,默认为0)来代表超过多大时就不在新生代分配,而是直接在老年代分配。②.大的数组对象,即数组中无引用外部对象。老年代所占的内存大小为-Xmx对应的值减去-Xmn对应的值。
5.程序计数器
是最小的一块内存区域,它的作用是当前线程所执行的字节码的行号指示器,在虚拟机的模型里,字节码解释器工作时就是通过改变这个计数器的值来选取下一条需要执行的字节码指令,分支、循环、异常处理、线程恢复等基础功能都需要依赖计数器完成。
转自若泽大数据公众号
-
JVM快速调优手册之一: 内存结构(堆内存和非堆内存)
2019-09-18 06:24:54也称”永久代” 、“非堆”, 它用于存储虚拟机加载的类信息、常量、静态变量、是各个线程共享的内存区域。默认最小值为16MB,最大值为64MB(未验证),可以通过-XX:PermSize 和 -XX:MaxPermSize 参数限制方法区的... -
JVM快速调优手册v1.0之一:内存结构(堆内存和非堆内存)
2018-08-13 10:39:51永久代” 、“非堆”, 它用于存储虚拟机加载的类信息、常量、静态变量、是各个线程共享的内存区域。默认最小值为16MB,最大值为64MB(未验证),可以通过-XX:PermSize 和 -XX:MaxPermSize 参数限制方法区的大小。 ... -
vs 编译器的堆空间不足_JVM快速调优手册之一:内存结构(堆内存和非堆内存)
2020-12-03 16:18:05图为Java虚拟机运行时的数据区:方法区也称"永久代” 、“非堆”, 它用于存储虚拟机加载的类信息、常量、静态变量、是各个线程共享的内存区域。默认最小值为16MB,最大值为64MB(未验证),可以通过-XX:PermSize 和 -... -
非堆内存的参数配置
2017-04-02 14:47:00方法区配置-XX:PerSize 初始永久区的大小-XX:MaxPermSize 最大永久区的大小栈配置-Xss 指定线程栈的大小直接内存配置直接内存跳过了Java堆,使java程序可以直接访问原生堆空间,它从一定程度上加快了内存空间的访问... -
了解非堆内存的参数配置
2017-11-02 07:36:33虚拟机还有一些内存用于方法区,线程栈和直接内存的使用。方法区配置: 方法区主要存放类的元信息。 在JDK1.6和1.7版本中,可以使用-XX:PermSize和-XX:MaxPermSize配置永久区大小。其中-XX:PermSize表示初始的永久... -
Tomcat和JBoss加大启动堆和非堆内存,防止内存溢出的方法
2011-04-11 09:48:00JBoss,找到%bin%/run.bat,用记事本打开,找到以下位置,并添加后面那段(即加大堆内存的方法): Tomcat, 在%Tomcat%/bin目录下,新建如:run1.bat文件,内容如下: set java_home=C:/j2sdk1.4.2_08 ... -
Java虚拟机--非堆内存的参数配置(五)
2017-03-27 23:06:46-XX:MaxPermSize:最大永久区; JDK1.8使用元数据区替代永久区: 默认情况下,元数据区只受系统可用内存的限制; -XX:MaxMetaspaceSize:用来指定永久区的最大可用值; 栈配置 栈是每个线程私有的内存空间; 在... -
IDEA中JVM使用-XX:PermSize设置非堆内存初始值
2018-11-11 20:49:49-server -XX:PermSize=128M -XX:MaxPermSize=256m -
java项目中经常碰到的内存溢出问题: java.lang.OutOfMemoryError: PermGen space, 堆内存和非堆内存,写的...
2016-04-29 08:43:25解决方案 在 catalina.bat 里的 蓝色代码前加入: set JAVA_OPTS=%JAVA_OPTS%-server -Xms800m -Xmx1024m -XX:PermSize=128m -XX:MaxPermSize=256m echo Using CATALINA_BASE: "%CATALINA_BASE%" 以下为 区别说明 : ... -
myeclipse 配置堆内存
2016-03-16 11:25:002.非堆内存分配 JVM使用-XX:PermSize设置非堆...由XX:MaxPermSize设置最大非堆内存的大小,默认是物理内存的1/4。 打开myeclipse.ini #utf8 (do not remove) #utf8 (do not remove) -startup ../Common/plugins/... -
Tomcat配置虚拟内存
2019-10-01 12:52:49一、Tomcat启动参数 JAVA_OPTS参数说明 -server 启用jdk 的 server 版; -Xms java 虚拟机初始化时的堆... -XX: PermSize 非堆内存永久保留区域 -XX:MaxPermSize 非堆内存最大永久保留区域 服务器参数配置... -
java项目中经常碰到的内存溢出问题: java.lang.OutOfMemoryError: PermGen space, 堆内存和非堆内存,...
2015-11-05 13:38:00Tomcat Xms Xmx PermSize MaxPermSize 区别 及 java.lang.OutOfMemoryError: PermGen space 解决 解决方案 在catalina.bat 里的蓝色代码前加入:红色代码 rem ----- Execute The Requested Command -------... -
jvm堆内存的设置
2020-02-22 12:56:45PermSize=64M -XX:MaxPermSize=128M-vmargs 说明后面是VM的参数,所以后面的其实都是JVM的参数了-Xms128m JVM初始分配的堆内存-Xmx512m JVM最大允许分配的堆内存,按需分配-XX:PermSize=64M JVM初始分配的非堆内存-... -
JVM基础之内存空间详解(四)
2019-04-11 12:25:08堆空间中进行的垃圾回收,是影响虚拟机性能的主要原因。自动垃圾回收机制是一把双刃...-XX:MaxPermSize 非堆内存允许最大值 堆内存参数 -XX:InitialHeapSize(-Xms) 堆内存初始大小值,单位可选m或g -XX:MaxHea... -
jvm中堆和非堆的划分
2017-04-21 11:47:58哪位大神能给我讲解一个问题,我们使用参数-Xms -Xmx设置堆内存的最小值和最大值,-XX:PermSize -XX:MaxPermSize设置非堆内存的最小值和最大值,这里的非堆内存包括Permanent Space(永久存储区)。但是为什么又说... -
配置tomcat服务器内存大小中的Xms、Xmx、PermSize、MaxPermSize 详解
2018-11-12 15:26:001.参数的含义 -vmargs -Xms256m -Xmx512m -XX:PermSize=256M -XX:MaxPermSize=512M -vmargs 说明后面是VM的参数,所以后面的其实都是JVM的参数了 ...-XX:PermSize=256M JVM初始分配的非堆内存 -XX:...