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

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

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

1、背景 TLDR;

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

1.2 适用场景

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

  • 网关服务
  • Web API

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

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

2、升级前后对比

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

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

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

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

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

CPU:4cMem: 6GB

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

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

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

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

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

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

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

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

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

2.1 GC 耗时对比

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

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

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

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

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

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

2.2 CPU 使用对比

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

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

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

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

3、升级方法

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

3.1 JDK 选择或安装

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

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

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

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

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

3.2 JVM 参数调整

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

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

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

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

参数释义

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

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

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

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

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

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

标签:
  • 热门焦点
  • 小米官宣:2023年上半年出货量中国第一!

    今日早间,小米电视官方微博带来消息,称2023年小米电视上半年出货量达到了中国第一,同时还表示小米电视的巨屏风暴即将开始。“公布一个好消息2023年#小米电视上半年出货量中国
  • 28个SpringBoot项目中常用注解,日常开发、求职面试不再懵圈

    前言在使用SpringBoot开发中或者在求职面试中都会使用到很多注解或者问到注解相关的知识。本文主要对一些常用的注解进行了总结,同时也会举出具体例子,供大家学习和参考。注解
  • 从零到英雄:高并发与性能优化的神奇之旅

    作者 | 波哥审校 | 重楼作为公司的架构师或者程序员,你是否曾经为公司的系统在面对高并发和性能瓶颈时感到手足无措或者焦头烂额呢?笔者在出道那会为此是吃尽了苦头的,不过也得
  • 共享单车的故事讲到哪了?

    来源丨海克财经与共享充电宝相差不多,共享单车已很久没有被国内热点新闻关照到了。除了一再涨价和用户直呼用不起了。近日多家媒体再发报道称,成都、天津、郑州等地多个共享单
  • 拼多多APP上线本地生活入口,群雄逐鹿万亿市场

    Tech星球(微信ID:tech618)文 | 陈桥辉 Tech星球独家获悉,拼多多在其APP内上线了&ldquo;本地生活&rdquo;入口,位置较深,位于首页的&ldquo;充值中心&rdquo;内,目前主要售卖美食相关的
  • 品牌洞察丨服务本地,美团直播成效几何?

    来源:17PR7月11日,美团App首页推荐位出现&ldquo;美团直播&rdquo;的固定入口。在直播聚合页面,外卖&ldquo;神枪手&rdquo;直播间、美团旅行直播间、美团买菜直播间等均已上线,同时
  • 东方甄选单飞:有些鸟注定是关不住的

    文/彭宽鸿编辑/罗卿东方甄选创始人俞敏洪带队的&ldquo;7天甘肃行&rdquo;直播活动已在近日顺利收官。成立后一年多时间里,东方甄选要脱离抖音自立门户的传闻不绝于耳,&ldquo;7
  • iQOO 11S新品发布会

    iQOO将在7月4日19:00举行新品发布会,推出杭州亚运会电竞赛事官方用机iQOO 11S。
  • 中关村论坛11月25日开幕,15位诺奖级大咖将发表演讲

    11月18日,记者从2022中关村论坛新闻发布会上获悉,中关村论坛将于11月25至30日在京举行。本届中关村论坛由科学技术部、国家发展改革委、工业和信息化部、国务
Top