将Java Flight Recorder与OpenJDK 11结合使用

Java Flight Recorder(JFR)曾经是Oracle JDK的商业附加组件。 由于它是与Java Mission Control一起最近开源的,因此使用OpenJDK 11的每个人现在都可以使用此出色的工具免费对Java应用程序进行故障排除。 JFR以前是专有解决方案,对于那些依赖OpenJDK早期版本的人来说,它可能鲜为人知。 因此,我认为有必要写一篇有关在OpenJDK 11中使用JFR的新文章。

Java飞行记录器

1.概述

关于Java Flight Recorder

JFR是一种分析工具,用于从正在运行的Java应用程序中收集诊断信息和分析数据。 它的性能开销可以忽略不计,通常低于1%。 对于运行时间较短的应用程序,此开销可能会超出该开销,因为JFR在启动时需要一些预热时间。

使用JFR诊断错误的应用程序可能会大大缩短解决时间。 从异常的出现开始就可以看出异常,直到出现异常,直到导致应用程序死机为止。 当然,并非所有问题都那么严重。 JFR收集有关正在运行的线程,GC周期,锁,套接字,内存使用量以及更多内容的数据。

Java Flight Recorder开源

正如我在介绍中提到的那样,该功能曾经是Oracle JDK的专有功能,并且正式地它仅适用于付费的Oracle客户。 实际上,您可以使用-XX:+UnlockCommercialFeatures -XX:+FlightRecorder标志启用它,并且早期的JVM不会强制使用许可证密钥或类似的东西。

甲骨文公司的马克·雷因霍尔德 ( Mark Reinhold)希望更快地推动Java的发展,并从发布周期为六个月的某些Linux操作系统中汲取灵感。 我认为他可能想到过Ubuntu,尽管他没有提及。 但是,从版本9开始的Java SE确实具有可预测的六个月发布周期。

长话短说,为了缩短发布时间,他们现在正在单一代码库上工作,这使得Oracle JDK和OpenJDK构建可以互换。 最终, 从Java 11开始,Oracle在开源GPL和商业许可下提供了JDK版本 。 如果您习惯于免费获取Oracle JDK二进制文件,请下载OpenJDK构建,它们在功能上是相同的。

结果,JFR获得了开源,并通过单一代码库简化了发布过程,从而使OpenJDK对开发人员更具吸引力。

JFR包装差异

使用-XX:+UnlockCommercialFeatures选项时,Oracle JDK 11会发出警告,而OpenJDK无法识别此选项并报告错误。

Java Mission Control也是开源的

JMC是用于打开生产时间性能和JFR产生的诊断记录的客户端工具 。 JMC还提供了其他功能,例如JMX控制台和堆转储分析器。 从7到10的Oracle JDK版本包含JMC,但已将其分离,现在可以单独下载获得 。

JMC最近也已经开源 ,这意味着现在使用OpenJDK 11的任何人都可以使用整个工具集(JFR + JMC)。在撰写本文时,第一个开源JMC版本7尚未发布到GA,但是提供了早期访问版本。

Java飞行记录器

2.使用飞行记录器

我一直没有在生产中连续使用JFR,因为那样会违反Oracle JDK的许可证。 为了发展,一切都可以根据我的最佳知识来使用。 因此,使用Oracle JDK的人们(没有支持合同)最终不得不在其开发机器上本地重现性能问题。

好吧,那么,让我们看一些代码。 这将是对Java Flight Recorder的基础知识的简单演示,我故意给我们一些调试方面的麻烦。

public class OOMEGenerator {static BlockingQueue<byte[]> queue = new LinkedBlockingQueue<>();public static void main(String[] args) {new Thread(new Consumer()).start();new Thread(new Producer()).start();}static class Producer implements Runnable {public void run() {while (true) {queue.offer(new byte[3 * 1024 * 1024]);try {Thread.sleep(50);} catch (InterruptedException e) {e.printStackTrace();}}}}static class Consumer implements Runnable {public void run() {while (true) {try {queue.take();Thread.sleep(100);} catch (InterruptedException e) {e.printStackTrace();}}}}}

为了展示经典的OOME,我们可以将新对象添加到集合中。 我选择了这一模式,因为我经常在生产中看到这种特定模式。 也就是说,有两个(或更多)组件,其中一些产生新的对象,而某些消耗这些对象。 问题源于这样一个事实,即内部缓冲区(组件通过该缓冲区进行通信)的容量可能不受限制。

当我说潜在的无限时,我的意思是缓冲区大小乘以一个平均对象的大小,它是如此之大,一段时间后,它只是吞噬了所有堆空间。 通常可能要花费数小时,数天或一周的时间,但最终会发生OutOfMemoryError

通常,开发人员认为在日志中看到OutOfMemoryError肯定反映了编程错误和内存泄漏。 有时,堆转储分析可以肯定地确认或混淆这一点,但是在某些情况下,它不是黑色还是白色,而您根本无法分辨。 在这些情况下,带有历史数据的JFR成为资源。

启用JFR

我们可以从上面的简短程序中看到一个OutOfMemoryError ,它需要一些时间,但是这将会发生。 使用JFR,我们可以详细了解GC的时间,CPU使用率和许多其他方面的时间过程以及错误的特征。

% java \-Xmx1024m \-Xlog:gc*=debug:file=gc.log:utctime,uptime,tid,level:filecount=10,filesize=128m \-XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=heapdump.hprof \-XX:StartFlightRecording=\disk=true, \dumponexit=true, \filename=recording.jfr, \maxsize=1024m,\maxage=1d,\settings=profile \path-to-gc-roots=true \OOMEGenerator Started recording 1.
Use jcmd 5469 JFR.dump name=1 to copy recording data to file.Exception in thread "main" java.lang.OutOfMemoryError: Java heap spaceat nl.wizenoze.storm.OOMEGenerator.main(OOMEGenerator.java:12)22.31s user 3.46s system 24% cpu 1:43.94 total

我在生产中使用这些调试设置。 从这种意义上说,这些JVM参数也为我自己提供了一个注释,当我需要它们时,我会在这里找到它们。

与JFR相关的是突出显示的部分(第5-11行)。 默认情况下,记录的最大大小,最长的期限或记录的数据均不受限制。 我尝试了各种设置,并应用了maxagemaxsize被证明是有用的。 在早期的JDK版本中,JFR曾经具有更多设置,但是在版本11中它们简化了它们。

我想提醒您注意dumponexit选项。 在正常情况下,通常在停止捕获数据时将记录写入磁盘。 当JVM终止时,自然会发生这种情况。 但是,根据我的经验,当终止异常时,例如当堆空间不足时,则记录的大小可能为零字节。 尽管JFR设置的文档尚不清楚, dumponexit有什么区别,但我观察到,应用它对于从有问题的JVM中捕获数据是有利的。

JFR带有两个出厂的配置文件( defaultprofile ),它们定义了应将哪些事件保留到捕获的记录中。 如果未指定设置选项,则使用default配置文件。 在此示例中,我使用了更广泛的配置文件事件定义,还启用了跟踪GC根目录的路径的功能。 这些会给运行中的JVM带来更高的开销,我不建议在生产中使用它们。

按需捕获记录

只要有JVM,就会将性能数据写入磁盘,但是可以在任何给定时间使用JCMD实用程序按需导出记录。 JFR.check命令返回有关当前正在运行的记录的详细信息。

% jcmd PID JFR.check name=1
14647:
Recording 1: name=1 maxsize=1.0GB maxage=1d (running)

除此之外, JFR.dump允许您导出到目前为止已记录的所有内容,而不必等待正在运行的JVM终止或停止记录。

%jcmd 5469 JFR.dump name=1 filename=dump.jfr

JCMD实用程序提供了其他故障排除选项 。

分析JFR录音

如前所述,JMC必须单独下载。 尽管它只是一个早期访问版本,但我发现它完全可用,而没有遇到重大故障。 在JMC 6中,添加了“自动分析结果”屏幕,以帮助工程师更快地诊断问题。 我一直在使用较旧的JMC 5.5版本,发现此版本很有用,并且确实提供了有用的技巧。 它已正确地将OOMEGenerator$Producer标识为正在生成的源或大对象,并且还建议平衡线程之间的分配率。

Java飞行记录器

从内存视图提供堆使用情况的角度来看,它是可以的,但是由于某些原因,对象直方图列表中的数字丢失了。 由于JMC的较旧版本无法打开此录音,因此我不知道该录音的样子。 我认为这可能是一个错误。

Java飞行记录器

看到GC暂停时间以及堆大小分配更改也很有用,但是在较早的JMC版本中,这种情况看起来更好。

Java飞行记录器

3.注意事项

  • JFR记录不向后兼容 – OpenJDK 11产生的记录不向后兼容,并且较旧的JMC版本(尝试5.5和6)不会打开它们
  • JMC 7仍然是早期访问版本 – GA中的功能可能会更改,并且某些错误可能会在这里和那里潜伏
  • 官方Docker映像中有一个错误 –启用JFR时阻止JVM启动
  • JMC 7无法分析HPROF文件 -尽管OpenJDK的Wiki声明它能够做到这一点

4。结论

Java Flight Recorder(JFR)是一种分析工具,用于从运行的Java应用程序收集诊断信息和分析数据。 它收集有关正在运行的线程,GC周期,锁,套接字,内存使用量以及更多内容的数据。 JFR和Java Mission Control(一种用于分析记录的工具)已经开源,并且不再是Oracle的专有产品。 Oracle的这一举动使OpenJDK对开发人员更具吸引力。

从11版开始,Java Mission Control尚未与JDK捆绑在一起,但可以单独下载获得 。

使用伪应用程序,我们有意生成了OutOfMemoryError ,捕获了堆转储和JFR记录,并使用JMC分析了后者。

JFR和JMC是OpenJDK开源领域中的新事物,而OpenJDK 11在撰写本文时也很新,因此必须经过一段时间才能使这些工具成熟。

翻译自: https://www.javacodegeeks.com/2018/12/using-java-flight-recorder-openjdk-11.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/344930.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

c语言开发工具程序代码是什么文件,【C语言】开发工具--GCC使用入门

来自&#xff1a; 51CTO GCC使用入门通常所说的GCC是GUN Compiler Collection的简称&#xff0c;除了编译程序之外&#xff0c;它还含其他相关工具&#xff0c;所以它能把易于人类使用的高级语言编写的源代码构建成计算机能够直接执行的二进制代码。GCC是Linux平台下最常用的编…

无服务器安全性:将其置于自动驾驶仪上

Ack &#xff1a;本文是从个人经验以及从无服务器安全性的其他多个来源学到的东西的混合。 我无法在这里列出或确认所有这些信息&#xff1b; 但是&#xff0c;应该特别感谢The Register &#xff0c; Hacker Noon &#xff0c; PureSec以及Serverless Status和Serverless&…

c语言构造报文,构造一个缓冲区溢出的C语言的例子

满意答案wk05122013.06.01采纳率&#xff1a;45% 等级&#xff1a;12已帮助&#xff1a;15719人#include #include #include void function(char *str){char buffer[16];strcpy(buffer, str);}void evilfunc(){printf("Am I Evil?\n");}int main(int argc, char*…

mongodb插入速度每秒_MongoDB事实:商品硬件上每秒插入80000次以上

mongodb插入速度每秒在尝试一些时间序列集合时&#xff0c;我需要一个大型数据集来检查我们的聚合查询在增加数据负载的情况下不会成为瓶颈。 我们解决了5000万份文档&#xff0c;因为超出此数目我们仍然会考虑分片。 每次事件如下所示&#xff1a; {"_id" : Objec…

parallels for linux,在 Parallels Desktop 上安装 Remix OS PC

前言个人觉得呢&#xff0c;像 Remix OS 和 Phoenix OS 这样的国产安卓桌面操作系统还是很划时代的。赋予了安卓平台多任务操作的能力&#xff0c;这可以给二合一设备的体验带来一定的变化&#xff0c;但是不像 Surface 一样后面有巨硬给撑腰可以做大做强起来&#xff0c;但是这…

模拟用户输入并检查输出的简单方法

最近&#xff0c;我的一些学生向我询问了赫尔辛基大学MOOC提供的单元测试的机制&#xff0c;我检查了它们的实现&#xff0c;并认为这对于初学者了解实际发生的情况是有帮助的&#xff0c;因此在此发表了这篇小文章。 我们将以“机场”项目为例&#xff0c;这是OOP2第一周的最…

android bench内存测试,华为p10内存测试软件(androbench) v5.0.1 免费版

华为p10内存测试软件(androbench)其实是androbench这款内存测试软件&#xff0c;可以用于测试你的华为p10&#xff0c;是一款不错的华为p10内存测试软件&#xff0c;可以测试你的手机闪存性能&#xff0c;其他的手机也可以免费测试哦。华为p10内存测试软件介绍AndroBench是衡量…

android对话框字体大小,Android Dialog 设置字体大小的具体方法

先看下面图片&#xff1a;这是我在做登录页面的时候&#xff0c;调用系统的progressdialog 进行等待&#xff0c;可是看起来很不协调&#xff0c;左边的等待图片过大&#xff0c;右边文字过小&#xff0c;看起来老别扭&#xff0c;虽然功能上不存在什么问题&#xff0c;但是我有…

android custom toast,Android自定义Toast

核心代码&#xff1a;package com.huatec.myapplication;import android.content.Context;import android.graphics.Bitmap;import android.support.annotation.ColorInt;import android.support.annotation.DrawableRes;import android.view.Gravity;import android.view.Layo…

华为android打开usb调试模式,华为 PE-CL00 开启USB调试模式

我们要将华为 PE-CL00与电脑进行连接&#xff0c;就必须要打开华为 PE-CL00系统的调试模式&#xff0c;不同的系统版本打开调试模式的方法有所不同&#xff0c;在这里我们就谈谈华为 PE-CL00各种系统版本打开USB调试模式的方法。1、针对Android 2.1-2.2版本的系统&#xff1a;我…

API网关和AWS Lambda进行身份验证

当Foreach最初涉足微服务领域时&#xff0c;我们并没有真正构建微服务。 我们以为我们做到了&#xff0c;但是我们所有的服务中总存在一些逻辑。 当然&#xff0c;每个服务实际上应该只专注于自己的任务&#xff0c;而不应该专注于属于另一个微服务的事物。 我们这方面最明显的…

魅蓝x android 7,魅蓝x2什么时候发布 魅蓝x2发布时间最新消息

日前&#xff0c;魅蓝品牌掌门人李楠或kkk便在微博上放出“bluegate(蓝色大门)”这样一个句子&#xff0c;似乎暗示魅蓝品牌或在近期会有动作&#xff0c;并且由于该条微博的尾巴显示为“下款魅蓝Android”&#xff0c;所以在不少网友看来&#xff0c;或许预示着魅蓝将有新机即…

内存泄漏代码_调查内存泄漏第1部分–编写泄漏代码

内存泄漏代码前几天&#xff0c;我发现了这个小问题&#xff1a;该服务器运行了一段时间&#xff0c;然后掉下来了。 然后通过启动脚本重新启动&#xff0c;整个过程重复进行。 听起来并没有什么坏处&#xff0c;因为它虽然对数据造成了重大损失&#xff0c;但对业务的重要性并…

Java整数缓存-为什么Integer.valueOf(127)== Integer.valueOf(127)为True

在一次采访中&#xff0c;我的一个朋友被问到如果我们有两个Integer对象&#xff0c; Integer a 127; Integer b 127; Integer a 127; Integer b 127; 为什么当a b都持有两个单独的对象时&#xff0c;其值为true &#xff1f; 在本文中&#xff0c;我将尝试回答这个问题&a…

怎么删除计算机管理员用户密码,小编手把手教你Win10系统如何删除管理员账户密码...

一位用户反馈自己在windows10正式版系统电脑中设置了管理员账户密码&#xff0c;之后每次开机都需要输入密码才可以登录&#xff0c;感觉十分麻烦。那么&#xff0c;Win10系统下该如何删除管理员账户密码&#xff1f;接下来&#xff0c;系统之家小编就为大家分享下具体操作方法…

Hibernate事实:始终检查Criteria API SQL查询

Criteria API对于动态构建查询非常有用&#xff0c;但这是我使用它的唯一用例。 每当您有一个带有N个过滤器且可以以任意M个组合到达的UI时&#xff0c;就应该有一个API动态地构造查询&#xff0c;因为连接字符串始终是我所不愿使用的路径。 问题是&#xff0c;您是否知道您的…

以Spring方式构建企业Java应用程序

我认为可以肯定地说&#xff0c; Java EE在Java开发人员中享有很高的声誉。 尽管多年来确实在各个方面都有所改善&#xff0c;甚至将其改名为Eclipse Foundation成为Jakarta EE &#xff0c;但其苦味仍然相当浓厚。 另一方面&#xff0c;我们拥有Spring框架 &#xff08;或者为…

jaxb 映射 空字段_推土机:将JAXB对象映射到业务/域对象

jaxb 映射 空字段Dozer是开放源代码&#xff08; Apache 2许可 &#xff09;“ Java Bean到Java Bean映射器&#xff0c;可将数据从一个对象递归复制到另一个对象”。 正如从其主页上的描述所描述的那样&#xff0c;它用于映射两个JavaBeans实例&#xff0c;以在实例之间进行自…

常用计算机网络性能指标的是什么,什么是Bit?【计算机网络的性能指标】

比特(英语&#xff1a;Bit)&#xff0c;亦称二进制位&#xff0c;指二进制中的一位&#xff0c;是信息的最小单位。因此一个比特就是二进制数字中的一个 1 或 0Bit是Binary digit(二进制数字)的缩写&#xff0c;由数学家John Wilder Tukey提出(可能是1946年提出&#xff0c;但有…

使用AWS Lambda在Go中构建RESTful API

在本文中&#xff0c;我们将学习使用AWS Lambda在Go中设计&#xff0c;构建和部署RESTful API。 在开始之前&#xff0c;让我给您简要介绍一下AWS Lambda。 什么是AWS Lambda&#xff1f; AWS Lambda是一种无服务器计算服务&#xff0c;可运行我们的代码以响应事件并自动为我…