Java 性能调优工具

本文详细介绍了VisualVM这款强大的Java应用监控工具,包括其功能集成、性能监控的各个方面,如线程分析、CPU/Memory采样以及死锁检测,对于开发者理解和优化Java应用性能具有实际价值。
摘要由CSDN通过智能技术生成

故障诊断和性能监控的可视化工具

==============================================================================

Visual VM是一个功能强大的多合一故障诊断和性能监控的可视化工具,它集成了多种性能统计工具的功能,使用Visual VM可以替代jstat、jmap、jhat、jstack等工具。在命令行输入jvisualvm即可启动visualvm。

打开Visual VM之后,左边导航栏会显示出当前机器所有Java进程:

点击你想监控的程序即可对该程序进行监控,Visual VM的性能监控页一共有以下几个tab页:

概述页会显示程序的基本使用情况,比如,进程ID,系统属性,启动参数等。

通过监视页面,可以监视应用程序的CPU、堆、永久区、类加载器和线程数的整体情况,通过页面上的Perform GC和Heap Dump按钮还可以手动执行Full GC和生成堆快照。

线程页面会提供详细的线程信息,单击Thread Dump按钮可以导出当前所有线程的堆栈信息,如果Visual VM在当前线程中找到死锁,则会以十分显眼的方式在Threads页面给予提示。

抽样器可以对CPU和内存两个性能进行抽样,用于实时地监控程序。CPU采样器可以将CPU占用时间定位到方法,内存采样器可以查看当前程序的堆信息。下面是一个频繁调用的Java程序,我们会对改程序进行采样:

public class MethodTime {

static java.util.Random r=new java.util.Random();

static Map<String,String> map=null;

static{

map=new HashMap<String,String>();

map.put(“1”, “Java”);

map.put(“2”, “C++”);

map.put(“3”, “Delphi”);

map.put(“4”, “C”);

map.put(“5”, “Phython”);

}

public String getNameById(String id){

try {

Thread.sleep(1);

} catch (InterruptedException e) {

e.printStackTrace();

}

return map.get(id);

}

public List getNamesByIds(String ids){

List re=new ArrayList();

String[] strs=ids.split(“,”);

for(String id:strs){

re.add(getNameById(id));

}

return re;

}

public List getNamesByIdsBad(String ids){

List re=new ArrayList();

String[] strs=ids.split(“,”);

for(String id:strs){

//A bad code

getNameById(id);

re.add(getNameById(id));

}

return re;

}

public class NamesByIdsThread implements Runnable{

@Override

public void run() {

try{

while(true){

int c=r.nextInt(4);

String ids=“”;

for(int i=0;i<c;i++)

ids=Integer.toString((r.nextInt(4)+1))+“,”;

getNamesByIds(ids);

}

}catch(Exception e){

}

}

}

public class NamesByIdsBadThread implements Runnable{

@Override

public void run() {

try{

while(true){

int c=r.nextInt(4);

String ids=“”;

for(int i=0;i<c;i++)

ids=Integer.toString((r.nextInt(4)+1))+“,”;

getNamesByIdsBad(ids);

}

Java核心架构进阶知识点

面试成功其实都是必然发生的事情,因为在此之前我做足了充分的准备工作,不单单是纯粹的刷题,更多的还会去刷一些Java核心架构进阶知识点,比如:JVM、高并发、多线程、缓存、Spring相关、分布式、微服务、RPC、网络、设计模式、MQ、Redis、MySQL、设计模式、负载均衡、算法、数据结构、kafka、ZK、集群等。而这些也全被整理浓缩到了一份pdf——《Java核心架构进阶知识点整理》,全部都是精华中的精华,本着共赢的心态,好东西自然也是要分享的

image

image

image

内容颇多,篇幅却有限,这就不在过多的介绍了,大家可根据以上截图自行脑补

分享的

[外链图片转存中…(img-ihyrKxiI-1714315084572)]

[外链图片转存中…(img-zYCI4joj-1714315084573)]

[外链图片转存中…(img-JQlHbzER-1714315084573)]

内容颇多,篇幅却有限,这就不在过多的介绍了,大家可根据以上截图自行脑补

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

  • 11
    点赞
  • 22
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值