JVM专题十三:总结与整理(持续更新)

图解JVM

JVM与Java体系结构

JVM垃圾回收算法

JVM垃圾回收器

图解JVM主要是放了前面12个章节的我们给大家画的图,做了整体的汇总,大家可以根据图区回忆我们所说的内容,查缺补漏。

实战经验

1、项目中数据量多少,QPS与TPS最高多少、服务器配置怎样的?

我们项目根据不同服务数据不一样,之前待在某互联网保险公司有2kw最有的活跃用户,我们的核心服务是4核8g,峰值QPS 4-5000,tps-3-400

2、项目中如何选择垃圾回收器?为什么?


决策树基于处理器核心数、吞吐量需求、内存大小、JDK版本来推荐合适的Java垃圾回收器。一般有一下套路:

  1. 吞吐量优先:如果应用程序更在意吞吐量,选择Parallel垃圾回收器。

  2. 内存小于4G&JDK版本8:如果应用程序的内存需求小于4GB或者JDK8是*,选择CMS垃圾回收器。

  3. JDK版本大于8小于11:选择G1垃圾回收器。

  4. JDK版本大于12:如果使用的JDK版本大于或等于12,选择Shenandoah垃圾回收器。

但是任何套路的问题都不适用于所有场景,只是提供一个思路,主要还是要了解各个回收器的优缺点,然后根据自己项目的实际情况去设置。

3、会看GC日志吗,重点看那些参数

  1. GC日志: 这是Java虚拟机执行垃圾回收操作时的日志输出,帮助开发者了解内存使用情况和回收效率。

  2. Allocation Failure: 表示JVM尝试分配内存失败,这可能意味着内存不足。

  3. ParNew (promotion failed): 这是ParNew收集器的日志,用于新生代的垃圾回收。日志显示从7260K到7970K的内存使用,回收操作耗时0.0048975秒。

  4. CMS: 表示并发标记清除(Concurrent Mark-Sweep)收集器的操作,用于老年代的垃圾回收。日志显示从8194K减少到6836K的内存使用,耗时0.0049920秒。

  5. Heap: 表示JVM堆内存的配置和使用情况。

  6. Par New Generation: 新生代内存,总大小9216K,已使用2130K。包括Eden区、From Space和To Space。

  7. Concurrent Mark-Sweep Generation: 老年代内存,如模拟:总大小10240K,已使用6836K。

  8. Metaspace: 表示元空间内存的使用情况,用于存储类元数据。

  9. Class Space: 类空间内存,用于存储静态类型信息。

  10. Times: 显示了用户时间、系统时间和实际时间的消耗

4、知道常用linux调试排错命令吗

在Linux系统中,使用命令行工具进行问题排查是一种常见的做法。下面是一些常用的命令及其用途,这些命令可以帮助你进行Java问题的排查:

  1. grep: 用于文本搜索,可以快速查找包含特定文本的行。

    • 例子:grep "Error" log.txt 查找包含"Error"的行。
  2. awk: 强大的文本处理工具,用于分析和处理文本文件。

    • 例子:awk '/Error/ {print $1, $2}' log.txt 打印包含"Error"行的前两列。
  3. sed: 用于对文件进行编辑,可以执行查找和替换操作。

    • 例子:sed 's/Error/WARNING/' log.txt > new_log.txt 将所有"Error"替换为"WARNING"并输出到新文件。
  4. tail: 显示文件的最后几行,常用于查看日志文件的最新内容。

    • 例子:tail -f log.txt 实时查看日志文件的更新。
  5. find: 用于在文件系统中查找文件。

    • 例子:find / -name "*.log" 查找系统中所有以.log结尾的文件。
  6. netstat: 查看网络连接和端口使用情况。

    • 例子:netstat -tuln 查看所有TCP和UDP端口的使用情况。
  7. iptables: 查看防火墙设置。

    • 例子:iptables -L 列出所有防火墙规则。
  8. routeip route: 查看路由表。

    • 例子:route -n 或 ip route 显示路由表。
  9. top: 实时显示系统进程和资源使用情况。

    • 例子:top 显示实时的进程和资源使用情况。
  10. free: 查看内存使用情况。

    • 例子:free -m 以MB为单位显示内存使用情况。
  11. df: 查看磁盘空间使用情况。

    • 例子:df -h 以易读的格式显示磁盘使用情况。
  12. du: 查看目录或文件的大小。

    • 例子:du -sh /path/to/directory 显示指定目录的大小。
  13. vmstat: 查看虚拟内存和系统负载情况。

    • 例子:vmstat 1 每秒显示一次系统状态。
  14. lsblk: 查看所有块设备,即硬盘和分区。

    • 例子:lsblk 列出所有块设备。
  15. swapon: 查看所有交换分区的使用情况。

    • 例子:swapon -s 显示交换分区的使用情况。
  16. fdiskparted: 查看硬盘分区情况。

    • 例子:fdisk -l 或 parted -l 显示所有硬盘和分区。
  17. last: 查看用户登录日志。

    • 例子:last 显示用户登录记录。
  18. who: 查看当前活动用户。

    • 例子:who 显示当前登录的用户。
  19. w: 查看用户活动和系统负载。

    • 例子:w 显示当前登录用户和他们正在执行的命令。
  20. ps: 查看当前运行的进程。

    • 例子:ps aux 显示所有进程及其详细信息。
  21. systemctl: 查看和管理系统服务。

    • 例子:systemctl status apache2 查看apache2服务的状态。
  22. lsmod: 查看已加载的内核模块。

    • 例子:lsmod 列出所有已加载的模块。
  23. dmesg: 查看或分析内核消息。

    • 例子:dmesg | grep -i error 查找内核消息中的"Error"。
  24. tsar: 一个系统性能监控工具,可以查看系统、设备和环境信息。

    • 例子:tsar 显示系统性能监控数据。

使用这些工具可以帮助你诊断和解决Java应用程序在Linux系统上的问题。记得根据具体情况选择合适的命令和参数。

5、聊完linux常用命令,你知道Java有哪些常用排查问题的工具和命令吗

在Java问题排查和调试中,有一系列工具可以帮助开发者快速定位问题并进行修复。以下是一些常用的Java调试工具列表,以及它们的简要说明:

Java调试入门工具

  1. jps: 显示Java虚拟机进程状态,类似于ps -ef | grep java

    • 用法示例:jps -l 显示Java进程的本地虚拟机标识符和主类名称。
  2. jstack: 打印Java线程的堆栈跟踪,帮助分析线程状态。

    • 用法示例:jstack <pid> 打印指定进程ID的线程堆栈。
  3. jinfo: 显示Java配置信息,或动态地修改某些JVM参数。

    • 用法示例:jinfo -flags <pid> 显示指定进程的JVM启动参数。
  4. jmap: 生成堆转储快照,用于分析内存使用情况。

    • 用法示例:jmap -heap <pid> 打印指定进程的堆内存使用情况。
  5. jstat: 用于监控JVM的性能计数器。

    • 用法示例:jstat -gcutil <pid> 显示指定进程的垃圾收集统计信息。
  6. jdb: Java调试器,用于调试Java应用程序。

    • 用法示例:jdb -classpath <path> <class> 启动JDB并连接到指定类。
  7. CHLSDB: 用于分析和调试C/C++和Java混合应用程序。

  8. VisualVM: 一个图形界面的JVM监控和分析工具。

Java调试进阶工具

  1. btrace: 动态追踪Java应用程序的工具,可以在不重启应用的情况下添加追踪点。

  2. Greys: 一个动态追踪工具,可以运行时查看Java应用程序的内部状态。

  3. Arthas: 阿里巴巴开源的Java在线诊断工具。

  4. javOSize: 用于分析Java堆对象的大小。

  5. JProfiler: 一个商业性能分析工具,提供CPU、内存、线程和数据库分析功能。

目前大部分都是使用的Arthas,这个工具我们后面可以单独说下,这里简单给出常用的命令

Arthas 是一个由阿里巴巴开发并开源的Java诊断工具,它可以帮助开发者在生产环境中排查各种Java应用的性能问题。以下是Arthas提供的命令集及其简要说明:

JVM相关信息

  • dashboard: 显示当前系统的实时数据面板,包括CPU使用率、内存使用情况、GC情况等。
  • thread: 显示当前JVM的线程堆栈信息,可以查看线程状态和锁信息。
  • jvm: 显示当前JVM的信息,包括JVM参数、启动类路径等。
  • sysprop: 查看和修改JVM的系统属性。
  • sysenv: 查看JVM的环境变量。
  • vmoption: 查看和修改JVM的诊断相关选项。

日志和属性

  • logger: 查看和修改JVM的日志配置。
  • getstatic: 查看类的静态属性值。
  • ognl: 执行OGNL表达式,用于动态访问Java对象的属性和方法。

MBean信息

  • mbean: 查看JVM的MBean信息,可以用于监控和管理JVM的运行时信息。

堆内存分析

  • heapdump: 执行Java堆内存Dump,类似于jmap命令的heap dump功能,用于分析内存泄漏问题。

类和类加载器

  • sc: 查看JVM已加载的类信息,包括类名、类加载器、状态等。
  • sm: 查看已加载类的方法信息,包括方法名、参数、返回值等。
  • jad: 反编译指定已加载类的源码,便于查看和分析。
  • mc: 在内存中编译.java文件为.class文件。
  • redefine: 加载外部的.class文件,并重新定义到JVM中,实现热更新。
  • dump: Dump已加载类的字节码到特定目录,用于分析类定义。
  • classloader: 查看类加载器的继承树、URLs、类加载信息等。

使用Arthas可以帮助开发者在不重启应用的情况下,实时地对JVM进行监控和诊断。通过这些命令,开发者可以快速定位问题,优化应用性能。如果你需要更详细的使用说明或参数选项,可以在Arthas的命令行界面中输入命令名后跟-h参数(例如thread -h),以获取帮助信息。

          

6、谈完基础命令,根据这些命令我们常使用的调优参数有哪些?

关键的JVM内存参数及其说明:

  1. -Xms: 设置JVM启动时的初始堆大小。这个值决定了JVM启动时分配的最小内存量。

  2. -Xmx: 设置JVM可以使用的最大堆大小。这个值决定了JVM在运行时能够使用的最大内存量。

  3. -Xmn: 设置新生代的大小。新生代是JVM堆中用于存放新创建对象的区域。

  4. -Xss: 设置每个线程的栈大小。JDK 5及以上版本默认为1MB,之前的版本默认为256KB。

  5. -XX:NewRatio: 设置新生代与老年代的比值。例如,-XX:NewRatio=4 表示新生代占堆的1/5。

  6. -XX:PermSize: 设置持久代(PermGen)的初始大小。持久代用于存储类的元数据。

  7. -XX:MaxPermSize: 设置持久代的最大大小。

  8. -XX:MaxTenuringThreshold: 设置新生代中对象在被移动到老年代之前可以经历的最大GC次数。

  9. -XX:SurvivorRatio: 设置Eden区与Survivor区的大小比值。

  10. -XX:+UseFastAccessorMethods: 启用快速访问方法,优化原始类型访问。

  11. -XX:+AggressiveOpts: 启用编译器的激进优化选项。

  12. -XX:PretenureSizeThreshold: 设置对象超过此大小时直接在老年代中分配。

  13. StackOverflowError: 当线程请求的栈深度超过最大可用深度时抛出。

  14. OutOfMemoryError: 当JVM没有足够的内存空间来创建新线程时抛出。

经验建议:

  • -Xms 和 -Xmx 通常设置为相同的值,以避免JVM在运行时动态调整堆大小,减少性能开销。
  • -Xmn 的设置需要根据应用的内存需求和垃圾回收行为来调整。太小会增加Minor GC的频率,太大会减少老年代的大小。
  • -XX:SurvivorRatio 和 -XX:TargetSurvivorRatio 的设置会影响对象在新生代中的存活时间和晋升到老年代的条件。
  • 对于持久代的大小,如果应用中有很多动态类加载,可能需要增加 -XX:MaxPermSize 的值。但是,如果经常出现方法区溢出,应该考虑优化代码,减少动态类生成。

这些参数的设置需要根据具体的应用场景和性能测试结果来调整,以确保应用程序既稳定又高效地运行。

专题汇总

JVM专题一:深入分析Java工作机制

JVM专题二:Java如何进行编译的

JVM专题三:Java代码如何运行

JVM专题四:JVM的类加载机制

JVM专题五:类加载器与双亲委派机制

JVM专题六:JVM的内存模型

JVM专题七:JVM垃圾回收机制

JVM专题八:JVM如何判断可回收对象

JVM专题九:JVM分代知识点梳理

JVM专题十:JVM中的垃圾回收机制

JVM专题十一:JVM 中的收集器一

JVM专题十二:JVM 中的收集器二

JVM专题十三:总结与整理(面试常用)

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

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

相关文章

展开说说:Android列表之RecyclerView

RecyclerView 它是从Android5.0出现的全新列表组件&#xff0c;更加强大和灵活。用于显示列表形式 (list) 或者网格形式 (grid) 的数据&#xff0c;替代ListView和GridView成为Android主流的列表组件。可以说Android客户端只要有表格的地方就有RecyclerView。 RecyclerView 内…

技术速递|Visual Studio Code 的 .NET MAUI 扩展现已正式发布

作者&#xff1a;Maddy Montaquila 排版&#xff1a;Alan Wang 今天&#xff0c;我们非常高兴地宣布 .NET MAUI VS Code 扩展插件结束了预览阶段&#xff0c;并将包含一些期待已久的新功能 - 包括 XAML IntelliSense 和 Hot Reload&#xff01; 什么是 .NET MAUI 扩展插件&…

鸿蒙开发Ability Kit(程序框架服务):【ServiceAbility切换】 组件切换

ServiceAbility切换 FA模型中的ServiceAbility对应Stage模型中的ServiceExtensionAbility。Stage模型下的ServiceExtensionAbility为系统API&#xff0c;只有系统应用才可以创建。因此&#xff0c;FA模型的ServiceAbility的切换&#xff0c;对于系统应用和三方应用策略有所不同…

4A的「A」会变成AI的「A」吗?

戛纳国际创意节上&#xff0c;广告集团WPP的全球CEO Mark Read 和英国CEO Karen Blackett 解释了WPP如何应对AIGC所带来的「威胁」。同时&#xff0c;Mark Read 与Elon Musk对话&#xff0c;讨论「技术创新的变革力量&#xff0c;人工智能如何重塑创造力、商业和社会&#xff0…

Duix - 硅基数字人SDK

简介 Introduction DUIX(Dialogue User Interface System)是硅基智能打造的AI数字人智能交互平台。通过将数字人交互能力开源,开发者可自行接入多方大模型、语音识别(ASR)、语音合成(TTS)能力,实现数字人实时交互,并在Android和iOS多终端一键部署,让每个开发者可轻松…

基于长短时记忆网络LSTM的TE过程故障诊断(MATLAB R2021B)

实验所用 TE 仿真过程的数据集是网上公开的数据集&#xff0c;该数据集中的训练集和测试集分别包含 20 种故障工况和一种正常工况数据&#xff0c;其中所采集的每个样本信号包含 41 个测量变量和 11 个控制变量&#xff0c;所以每个时刻采集到的样本有 52 个观测变量。 TE 仿真…

IO流

文件 什么是文件 文件流 常用的文件操作 创建文件对象相关构造器和方法 public class FileCreate {public static void main(String[] args) {}//方式 1 new File(String pathname)//根据路径构建一个File对象Testpublic void create01() {String filePath "e:\\news1.…

TMGM:ASIC撤销禁令,TMGM强化合规、重启差价合约服务

TMGM作为差价合约&#xff08;CFDs&#xff09;与保证金外汇交易领域的领航者&#xff0c;安全、合规、高效被奉为我集团的终身使命。澳大利亚证券和投资委员会&#xff08;ASIC&#xff09;已正式撤销了早前针对TMGM差价合约业务实施的临时止损令。这一误会的解除&#xff0c;…

使用North自部署图床服务

图床 图床可以把图片转为链接&#xff0c;从而方便我们书写、分享博客&#xff0c;目前图床主要分为以下几类: 利用 Git 仓库存储对象存储&#xff08;OSS、COS、七牛云等&#xff09;免费公共图床&#xff08;SM.MS、聚合图床、ImgTP、Postimage等&#xff09; 但上述图床都…

Zabbix 监控系统部署

Zabbix 监控系统部署 Zabbix是一个企业级开源分布式监控解决方案&#xff0c;可监控网络的众多参数以及服务器、虚拟机、应用程序、服务、数据库、网站、云等的运行状况和完整性。 Zabbix 使用灵活的通知机制&#xff0c;允许用户为几乎任何事件配置基于电子邮件的警报。这允许…

Excel 宏录制与VBA编程 —— 12、文本字符串类型相关(转换、拆分、分割、连接、替换、查找、“Like“)

字符串分割&#xff0c;文末示例&#xff08;文末代码3附有源码&#xff09; 代码1 - 基础字符串 代码2 - 字符串拆分 代码3 - 字符串分割 Option ExplicitSub WorkbooksClear()Dim DataRange As RangeSet DataRange Range("C2:E12")DataRange.Clear End SubSub Wo…

活动|华院计算受邀参加2024全球人工智能技术大会(GAITC),探讨法律大模型如何赋能社会治理

6月22至23日&#xff0c;备受瞩目的2024全球人工智能技术大会&#xff08;GAITC&#xff09;在杭州市余杭区未来科技城隆重举行。本届大会以“交叉、融合、相生、共赢”为主题&#xff0c;集“会、展、赛”为一体&#xff0c;聚“产、学、研”于一堂。值得一提的是&#xff0c;…

C#——命名空间详情

命名空间 在 C# 中&#xff0c;可以将命名空间看作是一个范围&#xff0c;用来标注命名空间中成员的归属&#xff0c;一个命名空间中类与另一个命名空间中同名的类互不冲突&#xff0c;但在同一个命名空间中类的名称必须是唯一的。 定义命名空间 定义命名空间需要使用 namesp…

【设计模式】行为型-策略模式

策略模式&#xff0c;如春风吹过&#xff0c;随心所欲&#xff0c;变幻无穷&#xff0c;每一丝风都是一种选择。 文章目录 一、订单处理二、策略模式三、策略模式的核心组成四、运用策略模式五、策略模式的应用场景六、小结推荐阅读 一、订单处理 场景假设&#xff1a;有一个…

容器技术-docker5 (1)

一、docker-compose 常用命令和指令 1. 概要 默认的模板文件是 docker-compose.yml&#xff0c;其中定义的每个服务可以通过 image 指令指定镜像或 build 指令&#xff08;需要 Dockerfile&#xff09;来自动构建。 注意如果使用 build 指令&#xff0c;在 Dockerfile 中设置…

vscode刷LeetCode算法题环境配置

首先&#xff0c;下载nodejs 在vscode中安装LeetCode插件 安装好进行配置 选择leetcode-cn 填上刚才下载node.exe的路径 完成之后重启一下vscode 重启之后登陆LeetCode 完成之后就可以看到题目了 点击 code now 就可以开始刷题了

ueditor解决无法抓取远程背景图片问题的方法(php)

背景 laravel后台经常有用到编辑器的地方&#xff0c;Dcat使用的一般都是UEditor编辑器。最近项目经理在秀米排版以后&#xff0c;将内容复制到UEditor编辑器保存后发现&#xff0c; 在网站页面中发现图片竟然展示失败。经过浏览器控制台发现&#xff0c;图片的域名还是秀米的…

Arathi Basin (AB) PVP15

Arathi Basin &#xff08;AB&#xff09; PVP15 阿拉希盆地&#xff0c;PVP&#xff0c;15人战场

【手撕代码】握手机制

文章目录 为什么要握手握手信号无非3种可能 怎样实现握手案例一&#xff1a;数据反压 参考链接 为什么要握手 跨时钟域处理&#xff1a; 握手信号法其实也用到了脉冲展宽的方法&#xff0c;只是展宽信号的变化条件不同。因为如果不对脉冲进行展宽&#xff0c;慢速时钟域的时钟…

生产者发送数据,kafka服务器接收数据异常的问题记录

现象&#xff1a; 某个客户要求审计日志用kafka的方式传输给他们&#xff0c;使用了第三方的librdkafka库来开发。 往客户提供的kafka服务器上的一个topic发送数据&#xff0c;这个topic有三个分区&#xff0c;客户反馈接收到的数据和发送端发送的实际数量对不上&#xff0c;他…