java jvm部分命令 ~~还在完善中

命令整理

jps

-q 只输出进程号
-m main 函数的参数
-l 主类全名
-v 输出jvm参数

jstat

jstat -gc pid 1000 10

class gc gccapacity gcutil gccause gcnew gcnewcapacity gcold gcoldcapacity compiler printcompilation gcmetacapacity

jinfo

-sysprops pid

-flags pid

-flag ReservedCodeCacheSiz(参数) pid

jmap

jmap -dump:format=b,file= 11408

jhat 分析dump文件

jhat dump.hprof

jstack

jstack pid

参数

FieldsAllocationStyle 虚拟机策略分配参数

UseTLAB 本地线程分配缓冲

CompactFields 子类较窄的变量允许插入到父类变量的空隙中

HeapDumpOnOutOfMemoryError 堆溢出时虚拟机输出快照 java.lang.OutOfMemoryError: Java heap space

Xmn 新生代大小

Xms 最小堆

Xmx 最大堆 Xms=Xmx 堆内存不可扩展

Xoos 本地方法栈大小 没啥用

Xss 栈容量 虚拟机栈容量越大可以创建的线程数量就越小

前提:32位虚拟机

如果因为内存不够用导致不能创建更多的线程可以通过减少栈容量和堆容量的方式增加线程的数量

PrintGCDetails 垃圾回收GC信息

永久代 jdk7以前 限制常量池大小

PremSize

MaxPremSize

jdk7之后 永久代没有了 是元空间 premSize 就没有作用了 都在堆中 只有限制 Xmx才有作用

jdk8之后永久代完全退出

元空间设置

MaxMetaspaceSize -1不受限制

MeataspaceSize 设置初始化大小

MinMetaspaceFreeRatio 垃圾回收之后最小元空间百分比

MaxMetaspaceFreeRatio 用于控制最大元空间百分比

MaxDirectMemorySize 直接内存大小 默认和堆大小一致

相关推荐
小bo波4 小时前
使用Thread子类创建线程 VS 使用Runnable接口创建线程的区别
java·多线程·thread·并发编程·runnable
SamDeepThinking5 小时前
高并发场景下,CompletableFuture与ForkJoinPool该如何取舍?
java·后端·面试
张不才7 小时前
CPU 100% 了怎么办?Java 性能排障的标准化操作
java·后端
shepherd1119 小时前
吞吐量提升 10 倍:高并发大批量数据处理任务的架构演进与性能调优
java·后端·架构
plainGeekDev12 小时前
单例模式 → object 声明
android·java·kotlin
用户2986985301412 小时前
Java 实现 Word 文档文本与图片提取的方法
java·后端
SimonKing13 小时前
铁子,IntelliJ IDEA 2026.1.3来了,升不升?
java·后端·程序员
咖啡八杯1 天前
GoF设计模式——策略模式
java·后端·spring·设计模式
用户128526116021 天前
我把祖传Java项目重构后,接口响应从3s砍到了200ms,只改了这几行代码
java