当前位置:首页 > 科技  > 软件

新项目为什么建议你使用 JDK17,一文告诉你升级的方法和不可拒绝的理由!

来源: 责编: 时间:2024-05-29 17:30:43 223观看
导读1、背景 TLDR;垃圾回收器的暂停问题对实时响应要求较高的服务来说,一直是个痛点, CMS和G1等主流垃圾回收器的数十毫秒乃至上百毫秒的暂停时间相当致命。此外,调优门槛也相对较高,需要对垃圾回收器的内部机制有一定的了解,

1、背景 TLDR;

tHZ28资讯网——每日最新资讯28at.com

垃圾回收器的暂停问题对实时响应要求较高的服务来说,一直是个痛点, CMS和G1等主流垃圾回收器的数十毫秒乃至上百毫秒的暂停时间相当致命。此外,调优门槛也相对较高,需要对垃圾回收器的内部机制有一定的了解,才能够进行有效的调优。随着ZGC的出现, 使得这一痛点彻底解决, ZGC 最初在 JDK 11 中作为实验性功能引入,并在 JDK 15 中宣布为生产就绪, 由于 JDK17 才是比较正式提供给大众实用的LTS支持版本,而且一部分公司已经在使用,所以本文力推 JDK17。tHZ28资讯网——每日最新资讯28at.com

tHZ28资讯网——每日最新资讯28at.com

ZGC 作为一款低延迟垃圾收集器,旨在满足以下目标:tHZ28资讯网——每日最新资讯28at.com

tHZ28资讯网——每日最新资讯28at.com

  • 8MB 到 16TB 的堆大小支持
  • 10ms 最大 GC 暂时
  • 最糟糕的情况下吞吐量会降低 15%(实测,如果参数配置的问题可能更糟, 官方这个稍微吹牛了点, 说实话就是用 CPU 换 GC 时间,也没有那么高大上)

1.1 升级 JDK17 的不可拒绝的理由

tHZ28资讯网——每日最新资讯28at.com

低延迟的业务需求,毫秒级耗时的 GCtHZ28资讯网——每日最新资讯28at.com

tHZ28资讯网——每日最新资讯28at.com

据美团的开发说:tHZ28资讯网——每日最新资讯28at.com

tHZ28资讯网——每日最新资讯28at.com

在 Zeus 服务不同集群中,ZGC 在低延迟(TP999 < 200ms)场景中收益较大:tHZ28资讯网——每日最新资讯28at.com

  • TP999:下降 12~142ms,下降幅度 18%~74%。
  • TP99:下降 5~28ms,下降幅度 10%~47%。

tHZ28资讯网——每日最新资讯28at.com

可以忽略的升级 JDK17 的理由:tHZ28资讯网——每日最新资讯28at.com

tHZ28资讯网——每日最新资讯28at.com

  • 新版的 Spring Boot 官方最低支持 JDK17,想使用新Spring版本,就得升级;
  • JIT 编译器的增强;
  • JDK 17 中的新功能,例如 Sealed 类、Pattern Matching、Records 等;
  • 升级到 JDK 17 可以获得更好的安全性,包括修复的漏洞和强化的安全机制。

1.2 适用场景

tHZ28资讯网——每日最新资讯28at.com

  • 网关服务
  • Web API

tHZ28资讯网——每日最新资讯28at.com

暂不推荐场景:定时任务、批量任务、高 CPU 密集型应用。tHZ28资讯网——每日最新资讯28at.com

2、升级前后对比

tHZ28资讯网——每日最新资讯28at.com

话不多说,先看效果。tHZ28资讯网——每日最新资讯28at.com

tHZ28资讯网——每日最新资讯28at.com

环境:tHZ28资讯网——每日最新资讯28at.com

tHZ28资讯网——每日最新资讯28at.com

CPU:4cMem: 6GB

tHZ28资讯网——每日最新资讯28at.com

G1 参数:tHZ28资讯网——每日最新资讯28at.com

tHZ28资讯网——每日最新资讯28at.com

-Xmx3500m -Xms3500m -XX:+UseG1GC -XX:MaxGCPauseMillis=100-XX:G1ReservePercent=10 -XX:ConcGCThreads=2 -XX:ParallelGCThreads=5-XX:G1HeapRegionSize=16m -XX:MaxTenuringThreshold=14-XX:SurvivorRatio=8

tHZ28资讯网——每日最新资讯28at.com

ZGC 参数:tHZ28资讯网——每日最新资讯28at.com

tHZ28资讯网——每日最新资讯28at.com

--add-opens=java.base/java.lang=ALL-UNNAMED -Xms3500m -Xmx3500m -XX:ReservedCodeCacheSize=256m -XX:InitialCodeCacheSize=256m -XX:+UnlockExperimentalVMOptions -XX:+UseZGC -XX:ConcGCThreads=1 -XX:ParallelGCThreads=3 -XX:ZCollectionInterval=60 -XX:ZAllocationSpikeTolerance=4 -XX:+UnlockDiagnosticVMOptions -XX:-ZProactive  -Xlog:safepoint,classhisto*=trace,age*,gc*=info:file=/opt/gc-%t.log:time,tid,tags:filecount=5,filesize=50m

tHZ28资讯网——每日最新资讯28at.com

上述两个参数,均已经在生产环境实验过, 生产环境的机器是单机拥有 1500 业务  tps 的机器。tHZ28资讯网——每日最新资讯28at.com

tHZ28资讯网——每日最新资讯28at.com

2.1 GC 耗时对比

tHZ28资讯网——每日最新资讯28at.com

图片图片tHZ28资讯网——每日最新资讯28at.com

tHZ28资讯网——每日最新资讯28at.com

从上图可见, GC 耗时是有着质的区别的,这个区别是你用 CMS、Parallel GC、 G1 等呕心沥血也调校不出来的。tHZ28资讯网——每日最新资讯28at.com

这么短的GC, 可以保证,应用因为JVM层面的卡顿都保持在 1ms 以内, 这也是为啥说这点才是不能拒绝的理由。tHZ28资讯网——每日最新资讯28at.com

tHZ28资讯网——每日最新资讯28at.com

2.2 CPU 使用对比

tHZ28资讯网——每日最新资讯28at.com

图片tHZ28资讯网——每日最新资讯28at.com

tHZ28资讯网——每日最新资讯28at.com

从 CPU 使用上看, JDK17 相同的代码, 比 JDK8 要高出 10 ~ 20%tHZ28资讯网——每日最新资讯28at.com

3、升级方法

tHZ28资讯网——每日最新资讯28at.com

3.1 JDK 选择或安装

tHZ28资讯网——每日最新资讯28at.com

使用 JDK17 前必须要安装 JDK17, 对于不同的 Linux 发行版或者操作系统安装方法各不相同, 下面给出了一些样例, 仅供参考。tHZ28资讯网——每日最新资讯28at.com

tHZ28资讯网——每日最新资讯28at.com

# ubuntu 安装jdk17sudo apt install openjdk-17-jdk# docker 基础镜像docker pull openjdk:17-slimdocker pull openjdk:17-jdk-oraclelinux7FROM openjdk:17-slim

tHZ28资讯网——每日最新资讯28at.com

3.2 JVM 参数调整

tHZ28资讯网——每日最新资讯28at.com

有了 JDK17 后,已经具备了让你的 Java 程序运行在 JDK17 上的基本条件了,下一步便是配置 JVM 参数如下(有需要的话,可以自行把换行整理下):tHZ28资讯网——每日最新资讯28at.com

tHZ28资讯网——每日最新资讯28at.com

--add-opens=java.base/java.lang=ALL-UNNAMED /-Xms1500m -Xmx1500m /-XX:ReservedCodeCacheSize=256m /-XX:InitialCodeCacheSize=256m / -XX:+UnlockExperimentalVMOptions /-XX:+UseZGC /-XX:Cnotallow=1 -XX:ParallelGCThreads=2 /-XX:ZCollectinotallow=30 -XX:ZAllocatinotallow=5 /-XX:+UnlockDiagnosticVMOptions -XX:-ZProactive /-Xlog:safepoint,classhisto*=trace,age*,gc*=info:file=/opt/gc-%t.log:time,tid,tags:filecount=5,filesize=50m /-XX:+HeapDumpOnOutOfMemoryError /-XX:HeapDumpPath=/opt/errorDump.hprof

tHZ28资讯网——每日最新资讯28at.com

参数释义

图片图片tHZ28资讯网——每日最新资讯28at.com

tHZ28资讯网——每日最新资讯28at.com

本文链接:http://www.28at.com/showinfo-26-91523-0.html新项目为什么建议你使用 JDK17,一文告诉你升级的方法和不可拒绝的理由!

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: 有人问我架构图、流程图为什么这么好看?

下一篇: 服务失败后如何重试?你学会了吗?

标签:
  • 热门焦点
  • 三言两语说透设计模式的艺术-单例模式

    写在前面单例模式是一种常用的软件设计模式,它所创建的对象只有一个实例,且该实例易于被外界访问。单例对象由于只有一个实例,所以它可以方便地被系统中的其他对象共享,从而减少
  • JVM优化:实战OutOfMemoryError异常

    一、Java堆溢出堆内存中主要存放对象、数组等,只要不断地创建这些对象,并且保证 GC Roots 到对象之间有可达路径来避免垃 圾收集回收机制清除这些对象,当这些对象所占空间超过
  • 破圈是B站头上的紧箍咒

    来源 | 光子星球撰文 | 吴坤谚编辑 | 吴先之每年的暑期档都少不了瞄准追剧女孩们的古偶剧集,2021年有优酷的《山河令》,2022年有爱奇艺的《苍兰诀》,今年却轮到小破站抓住了追
  • 2天涨粉255万,又一赛道在抖音爆火

    来源:运营研究社作者 | 张知白编辑 | 杨佩汶设计 | 晏谈梦洁这个暑期,旅游赛道彻底火了:有的「地方」火了&mdash;&mdash;贵州村超旅游收入 1 个月超过 12 亿;有的「博主」火了&m
  • 中国家电海外掘金正当时|出海专题

    作者|吴南南编辑|胡展嘉运营|陈佳慧出品|零态LT(ID:LingTai_LT)2023年,出海市场战况空前,中国创业者在海外纷纷摩拳擦掌,以期能够把中国的商业模式、创业理念、战略打法输出海外,他们依
  • 造车两年股价跌六成,小米的估值逻辑变了吗?

    如果从小米官宣造车后的首个交易日起持有小米集团的股票,那么截至2023年上半年最后一个交易日,投资者将浮亏59.16%,同区间的恒生科技指数跌幅为52.78%
  • 超级标准版旗舰!iQOO 11S全球首发iQOO超算独显芯片

    上半年已接近尾声,截至目前各大品牌旗下的顶级旗舰都已悉数亮相,而下半年即将推出的顶级旗舰已经成为了数码圈爆料的主流,其中就包括全新的iQOO 11S系
  • 联想YOGA 16s 2022笔记本将要推出,屏幕支持触控功能

    联想此前宣布,将于11月2日19:30召开联想秋季轻薄新品发布会,推出联想 YOGA 16s 2022 笔记本等新品。官方称,YOGA 16s 2022 笔记本将搭载 16 英寸屏幕,并且是一
  • AI艺术欣赏体验会在上海梅赛德斯奔驰中心音乐俱乐部上演

    光影交错的镜像世界,虚实幻化的视觉奇观,虚拟偶像与真人共同主持,这些场景都出现在2019世界人工智能大会的舞台上。8月29日至31日,“AI艺术欣赏体验会”在上海
Top