1.JVM(java virtual mechinal)

()JVM有完善的硬件架构,如处理器、堆栈、寄存器当,还具有相应的指令系统。

()JVM的主要工作时解释自己的指令集(即字节码),并映射到本地的cpu的指令集或OS系统调用。

2.JVM虚拟机主要有堆、栈、本地方法栈、方法区组成

注:()堆和栈都是一种数据项按序排列的数据结构,只能在一端对数据项进行插入和删除。

  ()在单片机应用中,堆栈是个特殊的存储区,主要功能是暂时存放数据和地址,通常用来保护端点和现场。

  ()堆、队列,先进先出。

  ()栈,先进后出。

(1)堆

)所有通过new新建的对象,其内存在堆中分配,堆的大小可以通多-Xmx和-Xms来控制。

)堆被划分为新生代和旧生代。

)新生代又被进一步划分为Eden和Survivor区。

)Survivor由From Space和To Space组成。
)新生代,新建的对象都是用新生代分配内存。

)Eden空间不足的时候,会把存活的对象转移到Survivor中。

)新生代大小可以由-Xmn来控制,也可以用-XX:SurvivorRatio来控制Eden和Survivor的比例。
)旧生代,用于存放新生代中经过多次垃圾回收仍然存活的对象。
)持久带,(Permanent Space)实现方法区,主要存放所有已加载的类信息、方法信息、常量池等。

)可以通过-XX:PermSize和-XX:MaxPermSize来指定持久带初始化值和最大值。

)Permanent Space并不等同于方法区,只不过是Hostspot JVM用Permanent Space来实现方法区而已。

)有些虚拟机没有Permanent Space而用其他机制来实现方法区。
-Xmx    #最大堆内存
-Xms #初始时堆内存
-XX:MaxNewSize #最大年轻区内存
-XX:NewSize #初始时年轻区内存,通常为Xmx的1/3或1/4。
#新生代=Eden+2两个Survivor空间。
#实际可用空间=Eden+1个Survivor,即90%。
-XX:MaxPermSize    #最大持久带内存
-XX:PermSize #初始时持久带内存
-XX:+PrintGCDetails #打印GC信息
-XX:NewRation #新生代与老年代比例
#例:-XX:NewRetio=2,则新生代占整个堆空间的1/3,老年带占2/3 ;
-XX:SurvivorRatio #新生代中Eden与Survivor的比值。默认为8,即Eden占新生代空间8/10,另外两个Survivor各占1/10;

(2)栈

)每个线程执行每个方法的时候,都会在栈中申请一个栈帧。

)每个栈帧包括局部变量区和操作数栈,用于存放此方法调用过程中的临时变量参数和中间结果。

)-xss:设置每个线程堆栈大写.JDK1.+ ,每个线程堆栈大写为1M,如果栈不是很深,1M是够用的。

(3)本地方法栈

)用于支持native方法的执行,存储了每个native方法调用的状态。

(4)方法区

)存放要加载的类信息、静态变量、final类型的常量、属性和方法信息。

)JVM用持久带来存放方法区,可以通过-XX:PermSize和-XX:MaxPermSize来指定最小值和最大值。

)一个普通的java对象A出生在新生代的Eden区,当Eden区新生对象太多时,对象A会被调去Survivor区。

)Survivor区又分from区和to区;

)对象A有时会在from区,有时会在to区。

)一定时间后,对象A会被调到老年代。

)对象A在老年代达到一定时间时,就会被java回收。

3.tomcat性能优化

)Linux内核的优化

)服务器资源配置的优化

)tomcat参数优化

)配置负载集群优化
配置文件参数优化
()关闭DNS查询,配置最大并发;
()maxThreads:tomcat启动的最大线程数,即同时处理的任务个数,默认为200;
()acceptCount:当tomcat启动的线程数达到最大时,接受排队的请求个数,默认为100;
()这些值不是越大越好,需根据实际情况调整。
<Connector port="8080"
protocol="org.apache.coyote.http11.Http11NioProtocol"
connectionTimeout="20000"
redirectPort="443"
maxThreads="5000"
minSpareThreads="20"
acceptCount="10000"
disableUploadTimeout="true"
enableLookups="false"
URIEncoding="UTF-8" />
#以上配置 适用于128G 内存服务器
#参数注解:
protocol=“org.apache.coyote.http11.Http11NioProtocol” #调整工作模式为Nio
connectionTimeout=“20000” #连接超时,单位毫秒,0代表不限制,当前调整为20s。
redirectPort=“443” #当用户用http请求某个资源,而该资源本身又被设置了必须要https方式访问,此时Tomcat会自动重定向到这个redirectPort设置的https端口。
maxThreads=“5000” #最大线程数量,线程数量占用越多,内存和CPU占用会越多
minSpareThreads=“20” #最小空闲的线程数量
acceptCount=“10000” #请求最大值,超过10000,会接受客户的请求,但是会将请求放置到队列中。
disableUploadTimeout=“true” #禁用上传超时
enableLookups=“false” #关闭dns解析,提高响应时间
URIEncoding=“UTF-8” #设定字符集为UTF-8

4.JVM参数调整  vim bin/catalina.sh或 vim /etc/profile,在profile环境中配置需加export

CATALINA_OPTS="$CATALINA_OPTS -Xms512M -Xmx1024M -Xmn100M -XX:SurvivorRatio=4 -XX:+UseConcMarkS
weepGC -XX:CMSInitiatingOccupancyFraction= -DLOCALE=UTF-16LE -DRAMDISK=/ -DUSE_RAM_DISK=ture
-DRAM_DISK=true -Djava.rmi.server.hostname=192.168.111.128 -Dcom.sun.management.jmxremote.port
= -Dcom.sun.management.jmxremote.ssl=false -Dcom.sun.management.jmxremote.authenticate=false"
-Xms<size> #表示JVM初始化堆的大小:开启java程序最初开启占用的内存
-Xmx<size> #表示JVM堆的最大值 : 开启程序之后占用最大的内存
       #以上2个参数需要根据应用程序的需要的进行调整,如果使用的内存超出了最大值xmx,通常会提示内存溢出,也会导致程序崩溃。
       #建议-xmx 这个值通常会设置为当前内存的80%;
-xmn #表示年轻带的内存大小,推荐设置整个堆3/8的内存。

JVM虚拟机详解+Tomcat性能优化的更多相关文章

  1. 详解MySQL性能优化(二)

    http://www.jb51.net/article/70530.htm 七.MySQL数据库Schema设计的性能优化高效的模型设计 适度冗余-让Query尽两减少Join 大字段垂直分拆-sum ...

  2. MapReduce过程详解及其性能优化

    http://blog.csdn.net/aijiudu/article/details/72353510 废话不说直接来一张图如下: 从JVM的角度看Map和Reduce Map阶段包括: 第一读数 ...

  3. 高手详解SQL性能优化十条经验

    1.查询的模糊匹配 尽量避免在一个复杂查询里面使用 LIKE '%parm1%'—— 红色标识位置的百分号会导致相关列的索引无法使用,最好不要用. 解决办法: 其实只需要对该脚本略做改进,查询速度便会 ...

  4. 高手详解SQL性能优化十条建议

    1.查询的模糊匹配  尽量避免在一个复杂查询里面使用 LIKE '%parm1%'—— 红色标识位置的百分号会导致相关列的索引无法使用,最好不要用. 解决办法: 其实只需要对该脚本略做改进,查询速度便 ...

  5. MYSQL ini 配置文件详解及性能优化方案

    my.ini分为两块:Client Section和Server Section.   Client Section用来配置MySQL客户端参数.   要查看配置参数可以用下面的命令: show va ...

  6. JVM虚拟机详解

    1. 什么是JVM? JVM是Java Virtual Machine(Java虚拟机)的缩写,JVM是一种用于计算设备的规范,它是一个虚构出来的计算机,是通过在实际的计算机上仿真模拟各种计算机功能来 ...

  7. Java中JVM虚拟机详解

    1. 什么是JVM? JVM是Java Virtual Machine(Java虚拟机)的缩写,JVM是一种用于计算设备的规范,它是一个虚构出来的计算机,是通过在实际的计算机上仿真模拟各种计算机功能来 ...

  8. Java虚拟机详解----JVM常见问题总结

    [声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http://www.cnblogs.com/smyhvae/p/4 ...

  9. Java性能分析之线程栈详解与性能分析

    Java性能分析之线程栈详解 Java性能分析迈不过去的一个关键点是线程栈,新的性能班级也讲到了JVM这一块,所以本篇文章对线程栈进行基础知识普及以及如何对线程栈进行性能分析. 基本概念 线程堆栈也称 ...

随机推荐

  1. java常用类Time

    LocalDate:IOS格式(yyyy-MM-dd)日期 LocalTime:表示一个时间 LocalDateTime:表示时间日期 Instant 时间线上的瞬时点,可以用来记录应用程序中的时间时 ...

  2. Apache Solr Velocity模板远程代码执行复现

    0x01漏洞描述 2019年10月31日,国外安全研究员s00py在Github公开了一个Apache Solr Velocity模板注入远程命令执行的poc. 经过研究,发现该0day漏洞真实有效并 ...

  3. PL/SQL软件执行命令出现动态执行表不可访问,本会话的自动统计被禁止

    出现这样的原因是该用户没有相关权限. 解决方法: 去除软件层面设置

  4. 持续集成Gitlab CICD Runner&Jenkins

    目录 使用Gitlab Runner实现 再要部署的服务器上安装 gitlab runner 下载可执行文件 设置可执行权限权限 创建用户 运行服务 注册 Runner 到gitlab上找到需要用的U ...

  5. 比较器中的comparing方法以及涉及到的知识

    今天在学习Java核心技术集合程序清单9-3时遇到了问题. 代码如下 public class TreeSetTest { public static void main(String[] args) ...

  6. tp5验证码的使用

    <div><img id="verify_img" src="{:captcha_src()}" alt="验证码" on ...

  7. 020.掌握Pod-Pod基础使用

    一 Pod定义详解 1.1 完整Pod定义文件 apiVersion: v1 #必选,版本号,例如v1,版本号必须可以用 kubectl api-versions 查询到 kind: Pod #必选, ...

  8. .NET进阶篇06-async异步、thread多线程3

    知识需要不断积累.总结和沉淀,思考和写作是成长的催化剂 梯子 一.任务Task1.启动任务2.阻塞延续3.任务层次结构4.枚举参数5.任务取消6.任务结果7.异常二.并行Parallel1.Paral ...

  9. 【Linux系列】Centos 7部署Laravel项目(七)

    目的 本文主要介绍以下五点: 一. Composer安装 二. SSH设置 三. Git安装 四. Laravel部署 五. 上传GitHub 演示 一. Composer安装 # cd /usr/l ...

  10. PostGIS 查看表属性(字段、类型、是否为空)

     SELECT                a.attnum,                a.attname AS field,                t.typname AS type ...