scs653298 发表于 2018-12-3 06:47:26

tomcat 8 jvm 优化

jvm 的内存结构

    jvm 是按照运行时数据的存储结构来划分内存结构的,jvm在运行java 程序时,将他们划分成几 种不同格式的数据,分别存储在不同的区域,这些数据统一称为运行时数据。运行时数据包括java 程序本身的数据信息和jvm运行java 需要额外的数据信息。
jvm 运行时数据区

   程序技术器-----线程私有

   java 虚拟机栈--线程私有

   本地方法栈-----线程私有

      java堆----------线程公用

      方法区----------线程公用

jvm 内存分配

   保存参数、局部变量、中间计算过程和其他数据,退出方法的时候,修改栈顶指针就就可以把栈帧中的内容销毁。
   栈的优点:存取数据比堆快,仅此与寄存器,栈数据可以共享

   栈的缺点:存在栈中的数据大小,生存期是在编辑时就确定的,导致其缺乏灵活性。

   -Xss 每个线程使用的内存

   堆的有点:动态地分配内存大小,生存期不必事先告诉编辑器,它是在运行期动态动配分配的垃圾回收器会自动收走不在使用的空间区域
      堆内存机构如下图:

http://note.youdao.com/yws/res/5594/WEBRESOURCE6fd7de0ceca16f31a824e4f24f0b3129


年轻代:有eden 区和from 、to 组成,可以是说是e 区s1 s2 区之间的工作模式是开始线程全部进入eden 区域会后会通过copy 工作模式把需要的线程copy 到s1 或者s2 区域所有通过new 创建的对象内存都在堆中分配。其大小可以通过-Xms -Xmx 来控制,堆被划分为新生代和旧生代,新生代又被进一步划分为Eden 和Suruvivor 最后和Survior由formspace 和tospace 组成。

老年代大小=堆内存-新生代-持久带 因为老年代没有参数可控制所以新生态越大老年代越小。

java 堆结构和垃圾回收
http://note.youdao.com/yws/res/5597/WEBRESOURCEe84b2c75d720869946f444cb787fbf7b
说明:Non-Heap 是非堆内存信息
         Heap 堆内存信息也是新生代信息

jvm 堆配置参数

1、-Xms 初始化堆内存大小默认是物理内存的1/64 (
页: [1]
查看完整版本: tomcat 8 jvm 优化