java 虚拟机内存因程序需要已确定在2—4G范围内,请问怎样分配该内存较好。请各位大神给出几套方案!

java 虚拟机内存因程序需要已确定在2—4G范围内,请问怎样分配该内存较好。请各位大神给出几套方案!

适合的才是最好的,不要盲目的加参数
1. 首先呢,建议是把-Xms和-Xmx设置成一致,且设置为2G/4G,记得加-server参数,也就是在启动命令行保证如下参数

1
java -server -Xms2000m -Xmx2000m

2. 上面就完成了JVM的基本配置,建议此时对该JVM进行压力测试,并追加JVM的gc参数,分析内存的使用情况

1
java -server -Xms2000m -Xmx2000m -Xloggc:$CATALINA_HOME/logs/gc.log

3. 使用HPjmter或jprofile等对JVM的内存回收日志gc.log进行分析。看内存瓶颈在哪里,在对应分析调整。这个性能调优不是随便调的,盲目的调会有负作用。如果上述软件不知道的请GOOGLE之。

java jvm 的内存到底是什么分配的,看得有点糊涂。

一个完整的Java程序运行过程会涉及以下内存区域
 
         l  寄存器:JVM内部虚拟寄存器,存取速度非常快,程序不可控制
         l  栈:保存局部变量的值,包括:1.用来保存基本数据类型的值;2.保存类的实例,即堆区对象的引用(指针)。也可以用来保存加载方法时的帧。
         l  堆:用来存放动态产生的数据,比如new出来的对象。注意创建出来的对象只包含属于各自的成员变量,并不包括成员方法。因为同一个类的对象拥有各自的成员变量,存储在各自的堆中,但是他们共享该类的方法,并不是每创建一个对象就把成员方法复制一次。
         l  常量池:JVM为每个已加载的类型维护一个常量池,常量池就是这个类型用到的常量的一个有序集合。包括直接常量(基本类型,String)和对其他类型、方法、字段的符号引用(1)。池中的数据和数组一样通过索引访问。由于常量池包含了一个类型所有的对其他类型、方法、字段的符号引用,所以常量池在Java的动态链接中起了核心作用。常量池存在于堆中。
         l  代码段:用来存放从硬盘上读取的源程序代码。
         l  数据段:用来存放static定义的静态成员。

免责声明:本网信息来自于互联网,目的在于传递更多信息,并不代表本网赞同其观点。其原创性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容、文字的真实性、完整性、及时性本站不作任何保证或承诺,并请自行核实相关内容。本站不承担此类作品侵权行为的直接责任及连带责任。如若本网有任何内容侵犯您的权益,请及时联系我们,本站将会在24小时内处理完毕。
相关文章
返回顶部