JVM调优的基本概念:
在调整性能时,jvm有三个组件:
1、堆大小的调整
2、垃圾收集器的调整
3、JIT编译器
大多数调优选项都与调整堆大小和选择合适的垃圾收集器有关,JIT编译器对性能也有很大影响,但很少需要使用较新版本的jvm进行调优,
调优的目的是什么?
1、响应性
2、吞吐量
常用的一些JVM参数:
-xx:+AlwaysPreTouch jvm启动时分配内存,非使用时再分配
-xx:ErrorFile=filename 崩溃日志
–xx:+TraceClassLoading 跟踪类加载信息
–:+PrintClassHistogram 打印类的信息
-Xmx -Xms 最大堆和最小堆
-xx:permSize、-xx:metaspaceSize 永久代/元数据空间
-XX:+HeapDumpOnOutofMemoryError OOM时导出堆到文件
-XX:+HeapDumpPath OOM时导出的路径
–XX:OnOutOfMemoryError 在OOM时,执行一个脚本
GC调优的思路:
1、分析场景
例如:启动速度慢;偶尔出现响应慢于平均水平或者出现卡顿
2、确定目标
内存占用、低延时、吞吐量
3、收集日志
通过参数收集GC日志;通过JDK攻击查看GC状态
4、分析日志
使用工具辅助分析日志,查看GC次数。 GC时间
5、调整参数
切换垃圾收集器或者调整垃圾收集器参数
通用的GC参数
-XX:ParallelGCThreads 并行GC线程数量
-XX:ConcGCThreads 并发GC线程数量
-XX:MaxGCPauseMillis 最大停顿时间、单位毫秒GC尽力保证回收时间不超过设定值
-XX:GCTimeRatio 0-100取值范围垃圾收集时间占总时间的比默认99,即最大允许1%时间做GC
-XX:SurvivorRatio 设置Eden区大小和Survivor区大小的比例 8表示两个Survivor:Eden=2:8,即一个Survivor占年轻代的1/10
-XX:NewRatio 新生代和老年代的比
4 表示新生代:老年代=1:4, 即年轻代占堆的1/5
-XX:+PrintGCDetails 打印GC详细信息
-XX:+PrintGCTimeStampas 打印GC发生的时间戳
-Xloggc:log/gc.log 指定GC log的位置,以文件输出
-XX:+PrintHeapAtGC 每一次GC后,都打印堆信息
分析GC日志:辅助工具:
GCView
实时监控:jstat
获取内存dump的方式
1、获取内存详情:jmap -dump:format=b,file=e.b in pid
可以用jvisualvm.exe进行内存分析,或者采用工具
2、获取内存dump:jmap -histo:live pid
这种方式会出现fullgc,可以使用jmap -histo pid
3、第三种方式:jdk启动加参数
-xx:+HeapDumpBeforeFullGC
-XX:HeapDumpPath=/htts/logs/dump
这种方式会产生dump文件,再通过jvisualvm.ex工具进行分析
1.7、1.8默认的垃圾收集器
Parallel垃圾收集器
吞吐量优先的
-XX:+UseParallelGC 新生代使用并行回收收集器
-XX:+UseParallelOldGC 老年代使用并行回收收集器
-XX:ParallelGCThreads 设置用于垃圾回收的线程数
-XX:+UseAdaptiveSizePolicy 打开自适应 GC策略
CMS垃圾收集器的参数
响应时间优先
-XX:+UseConcMarkSweepGC 新生代使用并行收集器,老年代使用CMS+串行收集器
-XX:+UseParNewGC 在新生代使用并行收集器,cms下默认开启
-XX:CMSInitiatingOccupancyFraction 设置触发GC的阈值默认68%如果不幸内存预留空间不足,就会引起concurrent mode failure
-XX:+UseCMSCompactAtFullCollection Full GC后,进行一次整理整理过程是独占的,会引起停顿时间变长
-XX:+CMSFullGCsBeforeCompaction 设置进行几次FullGC后,进行一次碎片整理
-XX:+CMSClassUnloadingEnabled 允许对类元数据进行回收
-XX:+UseCMSInitiatingOccupancyOnly 表示只在达到阈值的时候才进行CMS回收
-XX:+CMSIncrementalMode 使用增量模式,比较适合单CPU;
片:
带尺寸的图片:
居中的图片:
居中并且带尺寸的图片:
当然,我们为了让用户更加便捷,我们增加了图片拖拽功能。
如何插入一段漂亮的代码片
去博客设置页面,选择一款你喜欢的代码片高亮样式,下面展示同样高亮的 代码片
.
// An highlighted block
var foo = 'bar';
生成一个适合你的列表
- 项目
- 项目
- 项目
- 项目
- 项目1
- 项目2
- 项目3
- 计划任务
- 完成任务
创建一个表格
一个简单的表格是这么创建的:
项目 | Value |
---|---|
电脑 | $1600 |
手机 | $12 |
导管 | $1 |
设定内容居中、居左、居右
使用:---------:
居中
使用:----------
居左
使用----------:
居右
第一列 | 第二列 | 第三列 |
---|---|---|
第一列文本居中 | 第二列文本居右 | 第三列文本居左 |
SmartyPants
SmartyPants将ASCII标点字符转换为“智能”印刷标点HTML实体。例如:
TYPE | ASCII | HTML |
---|---|---|
Single backticks | 'Isn't this fun?' | ‘Isn’t this fun?’ |
Quotes | "Isn't this fun?" | “Isn’t this fun?” |
Dashes | -- is en-dash, --- is em-dash | – is en-dash, — is em-dash |
创建一个自定义列表
-
Markdown
- Text-to- HTML conversion tool Authors
- John
- Luke
如何创建一个注脚
一个具有注脚的文本。1
注释也是必不可少的
Markdown将文本转换为 HTML。
KaTeX数学公式
您可以使用渲染LaTeX数学表达式 KaTeX:
Gamma公式展示 Γ ( n ) = ( n − 1 ) ! ∀ n ∈ N \Gamma(n) = (n-1)!\quad\forall n\in\mathbb N Γ(n)=(n−1)!∀n∈N 是通过欧拉积分
Γ ( z ) = ∫ 0 ∞ t z − 1 e − t d t . \Gamma(z) = \int_0^\infty t^{z-1}e^{-t}dt\,. Γ(z)=∫0∞tz−1e−tdt.
你可以找到更多关于的信息 LaTeX 数学表达式here.
新的甘特图功能,丰富你的文章
- 关于 甘特图 语法,参考 这儿,
UML 图表
可以使用UML图表进行渲染。 Mermaid. 例如下面产生的一个序列图:
这将产生一个流程图。:
- 关于 Mermaid 语法,参考 这儿,
FLowchart流程图
我们依旧会支持flowchart的流程图:
- 关于 Flowchart流程图 语法,参考 这儿.
导出与导入
导出
如果你想尝试使用此编辑器, 你可以在此篇文章任意编辑。当你完成了一篇文章的写作, 在上方工具栏找到 文章导出 ,生成一个.md文件或者.html文件进行本地保存。
导入
如果你想加载一篇你写过的.md文件,在上方工具栏可以选择导入功能进行对应扩展名的文件导入,
继续你的创作。
注脚的解释 ↩︎