jvm参数及分析工具
| -Xmx4G | 设置堆的最大内存大小为4GB,也可通过-XX:MaxHeapSize=4GB进行设置 |
| -Xms256m | 设置堆的初始内存大小为256兆,如果未设置此选项,则初始大小将设置为新生代和年老代分配的内存大小总和,也可通过-XX:InitialHeapSize=256m进行设置 |
| -Xmn256m | 设置新生代的初始内存大小和最大内存大小为256兆,也可通过-XX:NewSize=256m设置新生代初始内存大小、-XX:MaxNewSize=256m设置新生代最大内存大小 |
| -Xss256k | 设置每个线程的堆栈大小为256KB,也可通过-XX:ThreadStackSize=256k进行设置。默认值与运行环境有关,64位linux系统中默认值为1024KB |
| -XX:MetaspaceSize=256m |
Metaspace由于使用不断扩容到-XX:MetaspaceSize参数指定的量,就会发生FGC;且之后每次Metaspace扩容都会发生FGC。 Metaspace的初始容量一定是21807104(约20.8m)和MetaspaceSize及MaxMetaspaceSize设置的值无关,所以扩容区间是[20.8m, MaxMetaspaceSize) |
| -XX:MaxMetaspaceSize=256m | 设置元空间的最大本机内存为256兆 |
| -XX:NewRatio=1 | 设置年老代和新生代占用的内存空间的比值,即old/new=1,默认值是2 |
| -XX:NewSize=256m | 设置新生代的初始内存大小为256兆 |
| -XX:SurvivorRatio=4 | 设置Eden区和Survivor大小比值,即Eden/Survivor=4,该设置表明每个Survivor区在新生代中占1/6的空间,该设置默认值为8 |
|
-XX:PretenureSizeThreshold= 10240000 |
设置直接进入老年代的对象大小阈值。此处表示大于10M的对象直接进入老年代 |
| -XX:MaxTenuringThreshold=20 | 设置进入老年代的门槛,即对象在Survivor区之间拷贝了20次则将该对象复制到老年代 |
| -XX:MaxNewSize=256m | 设置新生代的最大内存大小为256兆 |
| -XX:InitialHeapSize=256m | 设置堆的初始内存大小为256兆 |
| -XX:MaxHeapSize=4GB | 设置堆的最大内存大小为4GB |
| -XX:PermSize=256m | 设置分配给永久代的空间(以字节为单位),如果超出则会触发垃圾回收。此选项在JDK 8中已弃用,并被该-XX:MetaspaceSize选项取代(原因是jdk1.8已经将永久代移到了本地内存中,称为MetaSpace) |
| -XX:MaxPermSize=256m | 设置最大永久生成空间大小(以字节为单位)。此选项在JDK 8中已弃用,并由该-XX:MaxMetaspaceSize选项取代。 |
| -XX:MaxGCPauseMillis=500 | 设置一次GC过程大的暂停时间,单位是毫秒 |
| -XX:GCTimeRatio=9 | 设置吞吐量为90%,计算公式N/(N+1),默认值为99 |
| -XX:+UseSerialGC | 使用串行垃圾收集器,默认情况下,禁用此选项,并根据计算机的配置和JVM的类型自动选择收集器 |
| -XX:+UseParallelGC | 开启并行垃圾收集器(也称为吞吐量收集器),对新生代开启此选项将自动开启-XX:+UseParallelOldGC,除非显示禁用它 |
| -XX:+UseParNewGC | 对新生代使用并行线程进行垃圾回收,设置-XX:+UseConcMarkSweepGC选项时会自动启用该选项,jdk1.8之后单独使用该配置已过时,必须配合-XX:+UseConcMarkSweepGC使用 |
| -XX:+UseParallelOldGC | 对老年代使用并行垃圾收集器,开启此选项时-XX:+UseParallelGC会自动被开启 |
| -XX:+UseConcMarkSweepGC | 开启并发标记清除垃圾收集器(仅对老年代有效),并自动开启-XX:+UseParNewGC且无法禁用 |
| -XX:ParallelGCThreads=2 | 设置新生代和老年代中并行垃圾收集器开启的线程数,默认值是系统可用CPU的数量 |
| -XX:+PrintGC | 允许打印GC信息 |
| -XX:+PrintGCDetails | 允许打印GX详细信息 |
| -XX:+PrintGCDateStamps | 允许打印GC日期戳 |
| -XX:+PrintGCTimeStamps | 允许打印GC时间戳 |
| -Xloggc:filename | gc日志输出到指定文件 |
以上参数意义可参照官方文档,https://docs.oracle.com/javase/8/docs/technotes/tools/unix/java.html
oracle官方文档表示,在以下配置的计算机上,默认情况下选择吞吐量垃圾收集器;初始堆大小为1/64的物理内存,最大为1GB;最大堆大小为1/4物理内存,最大为1GB:
①.2个以上处理器
②.2GB以上的物理内存
分析工具
jmap -heap pid
查看指定java进程的jvm参数和当前堆内各个区的内存使用情况(pid表示进程id)
jstack pid
查看指定java进程的栈内日志,主要用于分析线程的运行状况
jstat -gc pid 1000
每隔一秒统计一次gc的回收情况
jvm参数及分析工具的更多相关文章
- JVM参数配置&&命令工具
JVM参数配置 大致方向:JVM调优的目的是保证在一定吞吐量的情况下尽可能的减少GC次数,从而减少系统停顿时间,提高服务质量和效率. 其中减少GC次数的原则: 将新生代转换成老年代的数量降至最少(及时 ...
- jvm jstack log分析工具,在线分析
http://spotify.github.io/threaddump-analyzer Spotify提供的Web版在线分析工具,可以将锁或条件相关联的线程聚合到一起.
- JVM内存状况查看方法和分析工具
Java本身提供了多种丰富的方法和工具来帮助开发人员查看和分析GC及JVM内存的状况,同时开源界和商业界也有一些工具可用于查看.分析GC及JVM内存的状况.通过这些分析,可以排查程序中内存泄露的问题及 ...
- Tomcat优化和JVM分析工具
Tomcat的常见优化和JVM常见分析工具 Tomcat的常用优化配置 (1) 内存空间: /etc/sysconfig/tomcat JAVA_OPTS="-server -Xms32g ...
- Scala命令设置JVM参数的规则
Scala下设置JVM参数简单分析 Scala 启动shell脚本,简化后的scala REPL 启动命令大致如下所示: java -Xmx256M -Xms32M \-Xbootclasspath/ ...
- JDK工具(查看JVM参数、内存使用情况及分析等)
在JDK的bin目录下有很多命令行工具: 我们可以看到各个工具的体积基本上都稳定在27kb左右,这个不是JDK开发团队刻意为之的,而是因为这些工具大多数是jdk\lib\tools.jar类库的一 ...
- 【J2EE性能分析篇】JVM参数对J2EE性能优化的影响
一切J2EE应用都是基于JVM的,那么对于JVM的设置和监控,成为J2EE应用程序性能分析和性能优化的必然手段.今天Sincky和大家交流该话题.这里以Tomcat环境为例,其它WEB服务器如Jbos ...
- Java虚拟机------JVM分析工具
主要介绍JVM的分析工具: jps jps:Java Virtual Machine Process Status Tool http://docs.oracle.com/javase/1.5.0/d ...
- java自带的jvm分析工具
http://domark.iteye.com/blog/1924302 这段时间觉得很有必要对java的内存分析工具进行熟悉,这样以后出现机器负载较高,或者反应很慢的时候,我就可以查找原因了.上 ...
随机推荐
- javascript prop和attr的区别
在网上找了一些资料,通过自己去寻找,尝试,此次做一次总结. 1/ attr()是jQuery 1.0版本就有的函数, prop()是jQuery 1.6版本新增的函数.毫无疑问,在1.6之前, ...
- Caffe+CUDA8.0+CuDNNv5.1+OpenCV3.1+Ubuntu14.04 配置参考文献 以及 常见编译问题总结
Caffe + CUDA8.0 + CuDNNv5.1 + OpenCV3.1 + Ubuntu14.04 配置参考文献 ---- Wang Xiao Anhui University CVPR ...
- JAVA中的String类(详解)
Java.lang.String类是final类型的,因此不可以继承这个类.不能修改这个类.String是一个类不属于基本数据类型. 可以从源码中看到,String是一个final类型. String ...
- Project D | Digital life
I have a dream. 1999年黑客帝国就已经提出了数字化生命的雏形,近些年的黑镜和其他科幻电影更是脑洞大开,但是生命科学的进展却差强人意. 当今人类世界里有三大复杂系统:以细胞为基础的生命 ...
- 三个水杯——java,广度优先搜索
题目如下: 21-三个水杯 内存限制:64MB 时间限制:1000ms 特判: No通过数:51 提交数:137 难度:4 题目描述: 给出三个水杯,大小不一,并且只有最大的水杯的水是装满的,其余两个 ...
- helm一键 安装mariadb-ha(详细)
一. 二.单机安装一主一从 先创建对应pv https://github.com/helm/charts/blob/master/stable/mariadb/templates/master-sta ...
- 《SSO CAS单点系列》之 APP原生应用如何访问CAS认证中心
4.开发支持APP登录的移动服务端接口.接收APP登录请求,采用HttpClient转发至CAS认证中心登录,返回json数据解析并最终返回给客户端.本地会话采用redis维护,登录成功,返回acce ...
- jQuery的版本兼容问题
之前在做头像上传的时候,使用的jQuery是1.8.2的版本,然后头像上传做完后,发现项目用的jQuery版本是3.3.1的.由于两个版本的差距太大了.所以兼容很差. 3.3.1不支持剪切头像的某些函 ...
- xshell6 同时操作多个终端
当我们使用Xshell的时候,有时候需要同时建立多个会话,连接不同的服务器或者不同的用户,如何同时向所有会话发送同一指令呢?方法如下: 1.依次点击 查看 ---> 撰写 ---> 撰写 ...
- vue-文字块收缩与展开功能
在设计图中要求的效果为: 文字限制超过9行即隐藏,并显示“展开”按钮,点击按钮进行切换,控制文本全部展示和部分展示 在原本的实现过程中,使用了红框内的判断方式: 页面代码: 样式则规定嵌套元素给一个死 ...