当前位置: 首页 > news >正文

Java性能分析

0、问题代码:

代码问题其实很明显,但是这里主要是为了练习如何使用工具进行分析
所以最好先不要看代码,假装不知道程序逻辑,而是先通过工具去分析,再结合分析数据去看代码,从而推出问题点在哪

import java.util.ArrayList;
import java.util.List;public class PerfTest {public static void main(String[] args) {//这里随机器的配置不同,可以适当把线程数量改大一点for (int i = 0; i < 4; i++) {int index = i;new Thread(() -> {while (true) {for (int k = 0; k < 10; k++) {List<String> list = new ArrayList<>();String str = "" + index;for (int j = 0; j < 10000; j++) {str += "aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa"+j;}list.add(str);System.out.println(index+"_"+k);try {Thread.sleep(10);} catch (InterruptedException e) {throw new RuntimeException(e);}}try {Thread.sleep(10);} catch (InterruptedException e) {throw new RuntimeException(e);}}}).start();}}
}

运行:

javac PerfTest.java
java -Xmx100m PerfTest

通过jps命令找到PerfTest进程pid
top命令观察进程cpu使用情况
在这里插入图片描述
可以看到cpu使用超过400%

1、使用async-profiler进行分析

GitHub地址:https://github.com/async-profiler/async-profiler

wget https://github.com/jvm-profiling-tools/async-profiler/releases/download/v2.9/async-profiler-2.9-linux-x64.tar.gz
tar zxvf async-profiler-2.9-linux-x64.tar.gz
cd async-profiler-2.9-linux-x64
./profiler.sh -d 30 -f /tmp/flamegraph.html pid

把生成的flamegraph.html导出到本地用浏览器打开,如下图:
在这里插入图片描述
在这里插入图片描述
可以看出大部分cpu消耗都是在GC上

2、使用arthas分析

GitHub地址:https://github.com/alibaba/arthas

curl -O https://arthas.aliyun.com/arthas-boot.jar
java -jar arthas-boot.jar

进入arthasshell后,使用thread命令:
在这里插入图片描述
也可以看出GC线程消耗了大量的CPU

把线程数改成20之后,效果更明显
在这里插入图片描述

直接使用jstat -gcutil pid命令,也能看出频繁的触发gull gc
在这里插入图片描述

3、代码优化

这里代码问题其实已经很明显了,是一个经典的String做字符串拼接导致的性能问题,直接用String做字符串拼接会产生大量不必要的String对象,导致频繁GC。
改为使用StringBuilder就可以大大缓解了

优化后的代码:

import java.util.ArrayList;
import java.util.List;public class PerfTest2 {public static void main(String[] args) {for (int i = 0; i < 4; i++) {int index = i;new Thread(() -> {while (true) {for (int k = 0; k < 10; k++) {List<String> list = new ArrayList<>();StringBuilder str = new StringBuilder(50*10000);str.append(index);for (int j = 0; j < 10000; j++) {str.append("aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa"+j);}list.add(str.toString());System.out.println(index+"_"+k);try {Thread.sleep(10);} catch (InterruptedException e) {throw new RuntimeException(e);}}try {Thread.sleep(10);} catch (InterruptedException e) {throw new RuntimeException(e);}}}).start();}}
}

再次运行:

javac PerfTest2.java
java -Xmx100m PerfTest2

可以看到一个很明显的变化就是,控制台的输出速度快了很多,而且cpu占用也没那么高了,说明优化起到了很大的效果

然后再进一步测试,把线程数从4个改为20个
发现这时候cpu也开始变高,GC也变得很频繁
猜测是因为jvm分配的内存较小,导致内存紧张,频繁触发full gc(这里也可以用工具进行内存分析,但是懒得折腾了,后面有空再补充,如果有的话0.0)

通过java -Xmx1000m PerfTest2把内存调大十倍,再观察,cpu和gc都降下来了
(这里的操作和前面类似,就不再贴命令和截图了~~)

另外这里也延申一个问题,前面有问题的程序,也把内存调大十倍观察,这时候再观察:
1、cpu还是居高不下
2、gc大大缓解
3、程序执行性能得到提升,但还是很慢
这时候也只能结合arthas或者async profiler工具定位到cpu占用高的线程,结合阅读代码进行分析了

相关文章:

Java性能分析

0、问题代码&#xff1a; 代码问题其实很明显&#xff0c;但是这里主要是为了练习如何使用工具进行分析 所以最好先不要看代码&#xff0c;假装不知道程序逻辑&#xff0c;而是先通过工具去分析&#xff0c;再结合分析数据去看代码&#xff0c;从而推出问题点在哪 import jav…...

2023年阿里云ECS服务器S6/C6/G6/N4/R6/sn2ne/sn1ne/se1ne处理器CPU性能详解

阿里云ECS服务器S6/C6/G6/N4/R6/sn2ne/sn1ne/se1ne处理器CPU性能怎么样&#xff1f;阿里云服务器优惠活动机型有云服务器S6、计算型C6、通用型G6、内存型R6、云服务器N4、云服务器sn2ne、云服务器sn1ne、云服务器se1ne处理器CPU性能详解及使用场景说明。 1、阿里云服务器活动机…...

数据分析与SAS学习笔记8

过程步&#xff1a;一个典型的SAS完整程序&#xff1a; 代码说明&#xff1a; 1&#xff09;reg&#xff1a;回归分析&#xff1b; 2&#xff09;model&#xff1a;因变量和自变量。 proc开头部分叫过程步。 常用过程&#xff1a; SORT过程&#xff1a; PRINT过程与FORTMAT…...

切割多个conf文件Nginx和Apache配置多版本PHP

有时候我们的项目不可能都是同一个PHP版本&#xff0c;需要每个项目都配置不同版本的PHP&#xff0c;宝塔和PHPStudy就是通过以下配置实现的&#xff1a;Nginx切割conf&#xff08;非选&#xff09;在nginx.conf添加include vhosts/*.conf;这样Nginx会自动引入当前目录->vho…...

使用Navicat进行SSH加密方式连接MySQL数据库

前言近年来网络安全形式日趋严峻&#xff0c;为保障企业信息安全和业务连续性&#xff0c;越来越多的要求业务系统上线前需要满足等保要求。其中数据库作为存储数据的载体&#xff0c;安全更是重中之重。部分等保要求&#xff0c;mysql数据库不能通过直连方式连接&#xff0c;需…...

大数据Hadoop教程-学习笔记04【数据仓库基础与Apache Hive入门】

视频教程&#xff1a;哔哩哔哩网站&#xff1a;黑马大数据Hadoop入门视频教程 总时长&#xff1a;14:22:04教程资源: https://pan.baidu.com/s/1WYgyI3KgbzKzFD639lA-_g 提取码: 6666【P001-P017】大数据Hadoop教程-学习笔记01【大数据导论与Linux基础】【17p】【P018-P037】大…...

20230223 刚体上的两个点速度之间的关系

刚体上的两个点速度之间的关系 注意&#xff1a;这里所讨论的都是投影在惯性坐标系上的。 dMAdMOdOAdMOdCA−dCOd_{_{MA}}d_{_{MO}}d_{_{OA}}d_{_{MO}}d_{_{CA}}-d_{_{CO}}dMA​​dMO​​dOA​​dMO​​dCA​​−dCO​​ 求导 d˙MAd˙MOd˙CA−d˙CO\dot d_{_{MA}}\dot d_{_…...

17.1 Display system tasks

系统任务的显示组分为三类&#xff1a;显示和写入任务、选通监视任务和连续监视任务。17.1.1 The display and write tasks $display和$write系统任务的语法如语法17-1所示。 display_tasks ::display_task_name [ ( list_of_arguments ) ] ; display_task_name ::$display | …...

【4】linux命令每日分享——cd切换路径

大家好&#xff0c;这里是sdust-vrlab&#xff0c;Linux是一种免费使用和自由传播的 类UNIX操作系统&#xff0c;Linux的基本思想有两点&#xff1a;一切都是文件&#xff1b;每个文件都有确定的用途&#xff1b;linux涉及到IT行业的方方面面&#xff0c;在我们日常的学习中&am…...

诚邀您体验人工智能AI

近期&#xff0c;人工智能&#xff08;AI&#xff09;领域动作频频&#xff0c;OPENAI公司Chat GPT的出现&#xff0c;标志着人工智能的研究与应用已经进入了一个崭新的发展阶段&#xff0c;国内腾讯、阿里巴巴、百度、易网、国外微软、谷歌、苹果、IBM、Amazon&#xff0c;等互…...

【蓝桥杯集训·每日一题】AcWing 2058. 笨拙的手指

文章目录一、题目1、原题链接2、题目描述二、解题报告1、思路分析2、时间复杂度3、代码详解三、知识风暴哈希表秦九韶算法一、题目 1、原题链接 2058. 笨拙的手指 2、题目描述 奶牛贝茜正在学习如何在不同进制之间转换数字。 但是她总是犯错误&#xff0c;因为她无法轻易的用两…...

运维排查篇 | Linux 连接跟踪表满了怎么处理

nf_conntrack (在老版本的 Linux 内核中叫 ip_conntrack )是一个内核模块&#xff0c;用于跟踪一个网络连接的状态 一旦内核 netfilter 模块 conntrack 相关参数配置不合理&#xff0c;导致 nf_conntrack table full &#xff0c;就会出现丢包、连接无法建立的问题 这个问题其…...

docker网络基

本文简单介绍下&#xff0c;容器之间的网络访问、容器与宿主机之间的网络访问、宿主机上有哪些网络接口。lolocal的简写&#xff0c;本地回环地址&#xff0c;127.0.0.1&#xff0c;它代表本地虚拟设备接口&#xff0c;默认被看作是永远不会宕掉的接口eth0ethernet的简写&#…...

C++:谈谈单例模式的多种实现形式

文章目录实现 1&#xff1a;静态成员实现 2&#xff1a;atexit 懒汉模式实现 3&#xff1a;原子变量 懒汉模式实现4&#xff1a;atexit 饿汉模式* 实现5&#xff1a;magic static单例模式&#xff1a;保证一个类仅有一个实例&#xff0c;并提供一个该实例的全局访问点。 稳…...

【Spring Cloud Alibaba】007-Nacos 配置*

【Spring Cloud Alibaba】007-Nacos 配置* 文章目录【Spring Cloud Alibaba】007-Nacos 配置*一、概述1、概述2、对比 spring cloud config二、基本使用1、在管理界面新建配置2、启动权限3、 搭建 nacos-config 服务第一步&#xff1a;引入依赖第二步&#xff1a;修改 yaml 配置…...

《安富莱嵌入式周报》第304期:开源硬件耳机设计,AI单片机STM32N6已确定为M55内核,另外还有新品STM32H5, H50X, H7R, H7S发布

往期周报汇总地址&#xff1a;嵌入式周报 - uCOS & uCGUI & emWin & embOS & TouchGFX & ThreadX - 硬汉嵌入式论坛 - Powered by Discuz! 更新一期视频教程&#xff1a; 第6期ThreadX视频教程&#xff1a;图文并茂吃透RTOS运行机制&#xff0c;任务管理&…...

vuex篇

1.简介(1)vuexVuex 是一个专为 Vue.js 应用程序开发的状态管理模式 库vuex是为vue.js开发的状态管理模式、组件状态集中管理(2)单页面数据流状态发生变化, 视图就重新渲染state发生变化时, 导致view视图发生改变, 视图通过操作action行为, 又会使得state状态发生变化(3)使用场…...

嵌入式开发:在嵌入式应用程序中混合C和C++

许多嵌入式应用程序仍使用c语言编写&#xff0c;但越来越多的嵌入式开发人员现在使用C语言编写程序。某些应用程序甚至共享这两种语言。这有意义吗?C是嵌入式应用中最常用的编程语言。多年来&#xff0c;人们一直期待着向C过渡&#xff0c;但过渡速度相当缓慢。但是&#xff0…...

【2023/图对比/增强】MA-GCL: Model Augmentation Tricks for Graph Contrastive Learning

如果觉得我的分享有一定帮助&#xff0c;欢迎关注我的微信公众号 “码农的科研笔记”&#xff0c;了解更多我的算法和代码学习总结记录。或者点击链接扫码关注【2023/图对比/增强】MA-GCL: Model Augmentation Tricks for Graph Contrastive Learning 【2023/图对比/增强】MA-…...

TensorBoard自定义修改单条及多条曲线颜色

在深度学习可视化训练过程中&#xff0c;曲线颜色是随机的&#xff0c;想要将好看的曲线颜色图放到论文中&#xff0c;就得自定义曲线颜色&#xff0c;具体方法见下文。 目录一、下载svg文件二、修改svg文件三、修改后曲线颜色对比四、总结一、下载svg文件 在TensorBoard界面中…...

电子电路设计中7种关键接口技术解析与应用

1. 电路接口概述&#xff1a;信号传输的关键桥梁在嵌入式系统和电子电路设计中&#xff0c;接口技术就像城市之间的高速公路系统。当CPU需要与传感器"对话"&#xff0c;当存储器要与处理器"交换情报"&#xff0c;这些不同模块之间的信号传输总会面临三大挑…...

OpenClaw自动化监控:百川2-13B-4bits量化模型驱动的异常检测

OpenClaw自动化监控&#xff1a;百川2-13B-4bits量化模型驱动的异常检测 1. 为什么选择OpenClaw做自动化监控&#xff1f; 去年我负责的一个个人项目遇到了运维难题——每天需要手动检查服务器状态、扫描日志关键词、生成异常报告。这种重复性工作不仅耗时&#xff0c;还经常…...

ESP32 PSRAM容器库:STL容器外扩至外部伪静态RAM

1. PSRAM Containers 项目概述PSRAM Containers 是一个面向 ESP32 平台的嵌入式 C 内存容器库&#xff0c;其核心目标是将标准 STL 容器&#xff08;如std::vector、std::deque、std::list、std::map等&#xff09;的功能完整迁移至外部伪静态 RAM&#xff08;Pseudo-Static RA…...

基于Copula函数的多风场出力相关性分析场景生成与聚类削减方法(MATLAB实现)

考虑多风场出力相关性的可再生能源场景生成/风电场景生成&#xff0c;并通过聚类算法场景削减成几个场景&#xff0c;每个场景都有确定的出现概率。 完美复现《考虑多风电场出力 Copula 相关关系的场景生成方法》 Copula 函数(连接函数)描述空间相邻风电场间的相关性&#xff0…...

Nine PRO 邮箱 APP专业高级版 邮箱合集整理 一个就够了

软件简介&#xff1a; Nine 是一款面向 Android 的专业级电子邮件客户端&#xff0c;主打 Exchange 生态深度适配、本地数据存储与全链路安全&#xff0c;集邮件、日历、联系人、任务与笔记于一体&#xff0c;是商务办公与多账户管理的高效工具。 核心定位&#xff1a; 专为 …...

claw-code 源码详细分析:Parity Audit——如何用工程对比把「像不像」从口水战变成可重复报告?

涉及源码&#xff1a;src/parity_audit.py、src/reference_data/archive_surface_snapshot.json、commands_snapshot.json、tools_snapshot.json&#xff0c;src/main.py&#xff0c;tests/test_porting_workspace.py。1. 要解决什么问题 大型移植里&#xff0c;「我们已经很像…...

TVA在汽车零部件焊接点检测中的实操启示录(3)

TVA系统在汽车零部件焊接点检测的落地&#xff0c;并非简单的“设备安装调试”&#xff0c;而是一个涉及流程优化、人员适配、技术衔接的系统工程。不少企业技术主管因忽视落地全流程管控&#xff0c;出现“系统安装后无法正常运行”“员工不会操作”“检测流程与生产流程脱节”…...

POJ1673——探索三角形垂心的几何奥秘与算法实现

1. 三角形垂心的几何本质 第一次接触POJ1673这道题时&#xff0c;我被题目中"垂心"这个概念卡住了。后来才发现&#xff0c;垂心其实就是三角形三个高线的交点。什么是高线&#xff1f;就是从三角形一个顶点向对边作垂线&#xff0c;这条垂线就是高线。有趣的是&…...

ESP32开发环境搭建避坑指南:VScode+ESP-IDF 5.0保姆级教程(Windows版)

ESP32开发环境搭建避坑指南&#xff1a;VScodeESP-IDF 5.0保姆级教程&#xff08;Windows版&#xff09; 刚接触ESP32开发的Windows用户&#xff0c;往往在环境搭建阶段就会遇到各种"坑"。本文将从实际踩坑经验出发&#xff0c;手把手带你避开那些常见的陷阱&#xf…...

别再只看电流了!航模电调(ESC)的隐藏功能与安全机制深度解读

航模电调&#xff08;ESC&#xff09;的隐藏功能与安全机制深度解析 当你的航模飞机在高速俯冲时突然失去动力&#xff0c;或是悬停表演中电机莫名停转&#xff0c;这些惊险时刻往往与电调的保护机制密切相关。大多数玩家只把电调当作简单的"油门开关"&#xff0c;却…...