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

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

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

1、背景 TLDR;

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

1.2 适用场景

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

  • 网关服务
  • Web API

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

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

2、升级前后对比

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

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

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

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

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

CPU:4cMem: 6GB

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

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

0u628资讯网——每日最新资讯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

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

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

0u628资讯网——每日最新资讯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

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

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

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

2.1 GC 耗时对比

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

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

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

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

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

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

2.2 CPU 使用对比

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

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

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

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

3、升级方法

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

3.1 JDK 选择或安装

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

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

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

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

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

3.2 JVM 参数调整

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

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

0u628资讯网——每日最新资讯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

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

参数释义

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

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

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

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

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

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

标签:
  • 热门焦点
  • 7月安卓手机好评榜:三星S23Ultra好评率第一

    性能榜和性价比榜之后,我们来看最后的安卓手机好评榜,数据来源安兔兔评测,收集时间2023年7月1日至7月31日,仅限国内市场。第一名:三星Galaxy S23 Ultra好评率:95.71%在即将迎来新
  • Golang 中的 io 包详解:组合接口

    io.ReadWriter// ReadWriter is the interface that groups the basic Read and Write methods.type ReadWriter interface { Reader Writer}是对Reader和Writer接口的组合,
  • 微信语音大揭秘:为什么禁止转发?

    大家好,我是你们的小米。今天,我要和大家聊一个有趣的话题:为什么微信语音不可以转发?这是一个我们经常在日常使用中遇到的问题,也是一个让很多人好奇的问题。让我们一起来揭开这
  • 三万字盘点 Spring 九大核心基础功能

    大家好,我是三友~~今天来跟大家聊一聊Spring的9大核心基础功能。话不多说,先上目录:图片友情提示,本文过长,建议收藏,嘿嘿嘿!一、资源管理资源管理是Spring的一个核心的基础功能,不
  • 自动化在DevOps中的力量:简化软件开发和交付

    自动化在DevOps中扮演着重要角色,它提升了DevOps的效能。通过自动化工具和方法,DevOps团队可以实现以下目标:消除手动和重复性任务。简化流程。在整个软件开发生命周期中实现更
  • 本地生活这块肥肉,拼多多也想吃一口

    出品/壹览商业 作者/李彦编辑/木鱼拼多多也看上本地生活这块蛋糕了。近期,拼多多在App首页&ldquo;充值中心&rdquo;入口上线了本机生活界面。壹览商业发现,该界面目前主要
  • 小米MIX Fold 3下月亮相:今年唯一无短板的全能折叠屏

    这段时间以来,包括三星、一加、荣耀等等有不少品牌旗下的最新折叠屏旗舰都有新的进展,其中荣耀、三星都已陆续发布了最新的折叠屏旗舰,尤其号荣耀Magi
  • iQOO Neo8 Pro抢先上架:首发天玑9200+ 安卓性能之王

    经过了一段时间的密集爆料,昨日iQOO官方如期对外宣布:将于5月23日推出全新的iQOO Neo8系列新品,官方称这是一款拥有旗舰级性能调校的作品。随着发布时
  • Windows 11发布,微软一改往常对老机型开放的态度

    距离 Windows 11 发布已经过去一周,在过去一周里,很多数码爱好者围绕其对 Android 应用的支持、对老机型的升级问题展开了激烈讨论。与以往不同的是,在这次大
Top