欢迎来到天天文库
浏览记录
ID:8846256
大小:38.50 KB
页数:6页
时间:2018-04-09
《理解java虚拟机及tomcat调优配置详解》由会员上传分享,免费在线阅读,更多相关内容在应用文档-天天文库。
1、Jvm优化及简单介绍1、JVM内存区域模型运行的基本流程:Class文件—》类装载器—》内存区—》执行区—》本地库接口—》本地方法库内存区(大体上分为5块):重点是堆1.方法区也称"永久代”、“非堆”,它用于存储虚拟机加载的类信息、常量、静态变量、是各个线程共享的内存区域。默认最小值为16MB,最大值为64MB,可以通过-XX:PermSize和-XX:MaxPermSize参数限制方法区的大小,还可以选择不实现垃圾回收在这里,设置了也很少来这里回收。所以,一般设定为64M最大值比较好。2.虚拟机栈描述的是java方法执行的内存模型:每个方法被执行的时候都会创建一个
2、“栈帧”用于存储局部变量表(包括参数)、操作栈、方法出口等信息。每个方法被调用到执行完的过程,就对应着一个栈帧在虚拟机栈中从入栈到出栈的过程。声明周期与线程相同,是线程私有的。局部变量表存放了编译器可知的各种基本数据类型(boolean、byte、char、short、int、float、long、double)、对象引用(引用指针,并非对象本身),其中64位长度的long和double类型的数据会占用2个局部变量的空间,其余数据类型只占1个。局部变量表所需的内存空间在编译期间完成分配,当进入一个方法时,这个方法需要在栈帧中分配多大的局部变量是完全确定的,在运行期间
3、栈帧不会改变局部变量表的大小空间。3.本地方法栈与虚拟机栈基本类似,区别在于虚拟机栈为虚拟机执行的java方法服务,而本地方法栈则是为Native方法服务。4.堆(垃圾收集器管理的主要区域,所以内存优化最大的地方就在这,一下介绍的都是32位的系统,64位系统可以吃更大的内存)也叫做java堆、GC堆是java虚拟机所管理的内存中最大的一块内存区域,也是被各个线程共享的内存区域,在JVM启动时创建。该内存区域存放了对象实例及数组(所有new的对象)。其大小通过-Xms(最小值)和-Xmx(最大值)参数设置,-Xms为JVM启动时申请的最小内存,默认为操作系统物理内存的
4、1/64但小于1G(32位的系统),-Xmx为JVM可申请的最大内存,默认为物理内存的1/4但小于1G(如果你的电脑内存小于1G,那么占用的最大内存是物理内存的80%),默认当空余堆内存小于40%时,JVM会增大Heap到-Xmx指定的大小,可通过-XX:MinHeapFreeRation=来指定这个比列;当空余堆内存大于70%时,JVM会减小heap的大小到-Xms指定的大小,可通过XX:MaxHeapFreeRation=来指定这个比列,对于运行系统,为避免在运行时频繁调整Heap的大小,通常-Xms与-Xmx的值设成一样。堆又可以分为2块(年轻代+年老代)以下
5、就介绍年轻代和老年代↓由于现在收集器都是采用分代收集算法,堆被划分为新生代和老年代。新生代主要存储新创建的对象和尚未进入老年代的对象。老年代存储经过多次新生代GC(MinorGC)任然存活的对象。新生代:程序新创建的对象都是从新生代分配内存,新生代由EdenSpace和两块相同大小的SurvivorSpace(通常又称S0和S1或From和To)构成,可通过-Xmn参数来指定新生代的大小,也可以通过-XX:SurvivorRation来调整EdenSpace及SurvivorSpace的大小。老年代:用于存放经过多次新生代GC任然存活的对象,例如缓存对象,新建的对象
6、也有可能直接进入老年代,主要有两种情况:①.大对象,可通过启动参数设置-XX:PretenureSizeThreshold=1024(单位为字节,默认为0)来代表超过多大时就不在新生代分配,而是直接在老年代分配。②.大的数组对象,切数组中无引用外部对象。老年代所占的内存大小为-Xmx对应的值减去-Xmn对应的值。5.程序计数器是最小的一块内存区域,它的作用是当前线程所执行的字节码的行号指示器,在虚拟机的模型里,字节码解释器工作时就是通过改变这个计数器的值来选取下一条需要执行的字节码指令,分支、循环、异常处理、线程恢复等基础功能都需要依赖计数器完成。Tomcat5常用
7、优化和配置1、连接器优化:在tomcat配置文件server.xml中的配置中,和连接数相关的参数有:maxThreads:Tomcat使用线程来处理接收的每个请求。这个值表示Tomcat可创建的最大的线程数。默认值200。acceptCount:指定当所有可以使用的处理请求的线程数都被使用时,可以放到处理队列中的请求数,超过这个数的请求将不予处理。默认值10。minSpareThreads:Tomcat初始化时创建的线程数。默认值4。maxSpareThreads:一旦创建的线程超过这个值,Tomcat就会关闭不再需要的socket线程。默认值50。enabl
此文档下载收益归作者所有