jvm学习(2)——常用jvm参数

本文详细介绍了Java中三种重要的内存管理参数:Trace跟踪参数、堆的分配参数和栈的分配参数。包括如何调整堆内存大小、设置新生代与老年代比例、配置线程栈大小等,并提供了关于内存溢出时的处理策略。

主要是三种参数

       Trace跟踪参数

       堆的分配参数

       栈的分配参数

1.Trace跟踪参数

-XX:+PrintGCDetails            打印GC详细信息

-XX:+PrintGCDateStamps   输出GC的时间戳(以日期的形式,如 2013-05-04T21:53:59.234+0800)

-Xloggc:log/gc.log                将gc信息输出到文件,:后表示文件路径


2.堆的分配参数

-Xmx  最大化堆内存大小

–Xms  初始化对内存大小

程序在Runtime中含有三个信息分别是 

runtime.maxMemory() 即最大化堆内存大小

runtime.totalMemory() 当前运行分配的总内存大小,java会尽量维持在最小堆内存

runtime.freeMemory() 当前运行分配的总内存中有多少是没被占用的

堆内存 

由新生代和老年代组成,新生代中又分为两个Survivor区和eden

 

-Xmn                          设置新生代大小

-XX:NewRatio            新生代(eden+2*s)和老年代(不包含永久区)的比值 ,4 表示 新生代:老年代=1:4,即年轻代占堆的1/5

-XX:SurvivorRatio      设置两个Survivor区和eden的比 ,8表示 Survivor :eden=2:8,即一个Survivor占年轻代的1/10

如下图

 堆溢出问题

-XX:+HeapDumpOnOutOfMemoryError    OOM时导出堆到文件

-XX:+HeapDumpPath                                导出OOM的路径

如:

-Xmx20m -Xms5m -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=d:/a.dump

或者在堆溢出时执行一个脚本

nXX:OnOutOfMemoryError

OOM时,执行一个脚本

-XX:OnOutOfMemoryError=D:/tools/jdk1.7_40/bin/printstack.bat %p

 

堆内存总结:

根据实际事情调整新生代和幸存代的大小

方推荐新生代占堆的3/8

幸存代占新生代的1/10

OOM时,记得Dump出堆,确保可以排查现场问题

堆溢出错误:java.lang.OutOfMemoryError

*******有时候堆空间实际占用非常少,但是永久区溢出 一样抛出OOM


 

3.栈内存参数

-Xss 每个线程私有,对于线程运行不可缺少

常只有几百K    越大能容纳的线程数越少

定了函数调用的深度  越大能递归调用的次数越大

个线程都有独立的栈空间

部变量、参数 分配在栈上

栈空间溢出错误:java.lang.StackOverflowError

 

常见堆栈错误见链接https://blog.youkuaiyun.com/sinat_29912455/article/details/51125748

 

### Java JVM 的原理 Java 虚拟机 (JVM) 是一种抽象计算模型,它提供了一个运行环境来执行由 Java 编译器生成的字节码文件。通过这种方式,Java 实现了跨平台特性——一次编写,到处运行。 #### 1. **JVM 的核心功能** JVM 主要负责将 `.class` 字节码文件解释并映射到操作系统的本地指令集上[^1]。这一过程涉及多个阶段,包括但不限于编译、加载和执行。具体来说: - **编译**: 使用 `javac` 将源代码 (.java 文件) 编译为字节码 (.class 文件)。 - **加载**: JVM 中的类加载器会读取这些字节码文件并将它们加载到内存中[^3]。 - **验证**: 对于已加载的字节码,JVM 进行严格的校验以确保其安全性和一致性[^4]。 - **执行**: 经过解析后的字节码会被解释或者即时编译(JIT),从而转化为机器可识别的语言被执行[^2]。 #### 2. **类加载机制** 类加载是 JVM 工作流程中的重要环节之一。该机制不仅决定了如何以及何时加载特定类型的类定义至内存空间,还影响着整个应用程序的行为模式及其性能表现。通常情况下,类加载遵循如下几个主要步骤: - **加载(Loading)**: 查找二进制形式表示的目标类别,并创建相应的 Class 对象实例。 - **链接(Linking)**: - 验证:检查输入数据的有效性; - 准备:分配必要的存储资源给静态字段赋初值等准备工作; - 解析:替换符号引用为直接引用的过程。 - **初始化(Initialization)**: 执行 `<clinit>` 方法完成变量设置及其他初始化动作。 此过程中任何错误都可能导致应用崩溃或异常终止。 #### 3. **线程池与任务调度** 除了基本的功能外,JVM内部实现了一些高级特性,比如多线程管理就是其中之一。当涉及到并发处理时,ThreadPoolExecutor扮演了极其重要的角色。如果某个线程因为等待时间超限而被回收,则可能会抛出类似于下面这样的堆栈跟踪信息:`at java.util.concurrent.ThreadPoolExecutor.getTask(ThreadPoolExecutor.java:1067)` [^5].这表明当前线程正在尝试获取新任务但未能成功. --- ### Java JVM 的常见配置选项 为了优化 JVM 性能,开发者可以通过命令行参数调整各种配置项。以下是一些常用JVM 参数示例: ```bash -Xms<size> 设置初始堆大小 -Xmx<size> 设置最大堆大小 -XX:+UseG1GC 启用 G1 垃圾收集算法 -D<name>=<value> 定义系统属性 -server 启动服务器版 JVM(针对长期运行的应用) -client 启动客户端版 JVM(适合短生命周期的任务) ``` 上述每种参数都有助于改善不同场景下的程序效率和服务质量。例如增大 `-Xmx` 可以为大型对象提供更多可用内存;启用不同的垃圾回收策略则可能减少 GC 暂停时间等等。 --- ### 示例代码展示 这里给出一段简单的 Java 程序演示如何查看默认的最大堆尺寸: ```java public class JvmHeapSize { public static void main(String[] args){ long maxMemory = Runtime.getRuntime().maxMemory(); System.out.println("Max memory available to this process is "+maxMemory+" bytes."); } } ``` 以上脚本能够帮助我们理解实际环境中 JVM 分配了多少物理 RAM 来满足我们的需求。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值