jvm可利用多大的内存空间
操作系统
- 32 位 : 2的32次方 = 4G - 操作系统一半空间= 2g--jvm
- 64 位 : 2的64次方 = 16384PB -操作系统2G = 剩余空间
jvm调优原则
- gc时间足够小(堆内存设置小一些)
- gc次数足够少(堆内存设置大一些)
一般做调优要选取balance(平衡)的一种状态
什么是垃圾
没有被引用的对象就是垃圾
如何找到这些垃圾
- 引用计数法: 在程序计数器当一个对象的引用值变为0的时候,进行标记,无法解决循环引用问题
- 跟可达算法: 每个引用对象作为根节点向下寻找,解决循环引用问题
垃圾回收算法
- Mark-sweep 标记清除算法
- 标记哪些内存视为垃圾
- 直接清除被标记的垃圾
优点: 性能快
缺点: 会产生内存脆片
- Copying 拷贝算法
- 将内存空间分为两部分,分别存储可用空间和垃圾空间
- 清除垃圾对象后直接将存活对象移到可用空间里
优点: 没有内存碎片
缺点: 存在内存空间浪费
- Mark-compark 标记拷贝压缩算法
- 标记哪些内存区域是垃圾
- 将存货对象拷贝到另一端(连续空间)
- 清除剩下的垃圾
优点: 没有内存碎片,使用的是连续空间
缺点: 性能较慢,
垃圾回收器
- 串行化垃圾回收器
Serial(年轻代垃圾回收) + serial old : 支持单核心 cpu 垃圾回收
- 并行垃圾回收期
Parnew (年轻代垃圾回收): 是 Parallel scavenge 增强型垃圾回收器,主要是为
了更好和 cms 垃圾回收器相结合而开发的垃圾回收器。
Cms(老年代垃圾回收):垃圾回收时候和线程执行交叉进行。STW 耗时更少。
Parallel scavenge(年轻代垃圾回收):并行垃圾回收器,特点:stop the world gc
暂停时间稍微长
Parallel old(老年代垃圾回收): 并行垃圾回收器
- G1
同时支持老年代和新生代垃圾回收器
垃圾回收器选择
- Ps + Po
ps + po 都采用并行方式进行垃圾回收,适用于吞吐量优先的方式,jdk8 默认采用该方式
-XX:+UseParallelGC -XX:+UseParallelOldGC
- Paranew + cms
响应时间优先
-XX:+UseParNewGC -XX:+UseConcMarkSweepGC
- G1
同时支持新生代和老年代回收器
-XX:+UseG1GC
其他调优参数
nohup java -Xmx3550m -Xms3550m -Xmn2g -Xss256k -jar
jshop-web-1.0-SNAPSHOT.jar --spring.config.addition-location=application.yaml >
log.log 2>&1 & -XX:+PrintGCDetails -XX:+PrintGCTimeStamps -XX:+PrintGCDateStamps -XX:+PrintHeapAtGC
-Xloggc:gc.log
-Xmx :最大堆内存,一般情况下内存设置不能超过80%,一般设置为50%-80%
-Xms : 初始化堆内存,这个内存一般情况下都必须和Xmx设置为一致大小
-Xmn : 设置年轻代大小
-Xss : 每一个线程堆栈大小,这个大小可以限制线程数量,默认为1M
gc日志
-XX:+PrintGCDetails -XX:+PrintGCTimeStamps -XX:+PrintGCDateStamps -XX:+PrintHeapAtGC
-Xloggc:gc.log
内存分带模型
年轻代
- Eden : 对象诞生的地方
- S1 :
- S2 : S1和S2在每次回收时进行标记增加年龄,互相拷贝到对方的内存中
老年代
- Old Generation : 默认年轻代15岁后进入老年代(可配置)
持久代
- Perm/Meta