Java 性能调优工具

Java 性能调优工具Java 性能调优工具

大家好,又见面了,我是你们的朋友全栈君。

CPU使用率

工具: vmstat

检查应用性能时,应该首先审查CPU时间。
代码优化的目的是提升而不是降低(更短时间段内的)CPU的使用率。
在试图深入优化应用前,应该先弄清楚为何CPU使用率低。

磁盘使用率

工具: iostat

对于所有应用来说,监控磁盘使用率非常重要。即便不直接写磁盘的应用,系统交换仍会影响它们的性能。
写入磁盘的应用遇到瓶颈,是因为写入数据的效率不高(吞吐率太低),或者是因为写入太多数据(吞吐率太高)。

网络使用率

工具: netstat nicstat

对于基于网络的应用来说,务必要监控网络以确保它不是瓶颈。
往网络写数据的应用遇到瓶颈,可能是因为写数据的效率太低(吞吐率太低),或者是因为写入了太多数据(吞吐率太高)。

Java监控工具

jcmd: 打印java进程涉及的基本类,线程和VM信息。
jconsole: 提供JVM活动的图形化视图,包括线程的使用,类的使用和GC活动。
jhat: 读取内存堆转储,并有助于分析。
jmap: 提供堆转储和其他JVM内存使用的信息。
jinfo: 查看JVM的系统属性,可以动态设置的一些系统属性。
jstack: 转储Java进程的栈信息。
jstat: 提供GC和类装载活动的信息。
jvisualvm: 监视JVM的GUI工具,可以用来剖析运行的应用,分析JVM堆转储。

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

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<String> getNamesByIds(String ids){
        List<String> re=new ArrayList<String>();
        String[] strs=ids.split(",");
        for(String id:strs){
            re.add(getNameById(id));
        }
        return re;
    }
    public List<String> getNamesByIdsBad(String ids){
        List<String> re=new ArrayList<String>();
        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);
                }
            }catch(Exception e){

            }
        }
    }
    public static void main(String args[]){
        MethodTime instance=new MethodTime();
        new Thread(instance.new NamesByIdsThread()).start();
        new Thread(instance.new NamesByIdsBadThread()).start();

    }

}

通过Visual VM的采样功能,可以找到改程序中占用CPU时间最长的方法:
默认Visual VM不统计内置对象的函数调用,比如java.*包中的类,如果要统计这些内置对象,单机右上角的设置进行调配。Visual VM虽然可以统计方法的调用时间,但是无法给出方法调用堆栈,Jprofile不仅可以给出方法调用时间,还可以给出方法调用堆栈,较Visual VM更强大。
右击左导航的应用程序,会出现以下菜单:
单机应用程序快照,可以分析当前应用程序的快照,单击堆Dump能够对当前的堆信息进行分析。Visual VM的更多使用方法,可以查看Oracle的官方文档文档链接

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/106413.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • js 修改全局变量

    js 修改全局变量一般在方法里对全局变量的修改仅限于方法体内,方法结束之后,全局变量就会恢复之前的值,在前端的js代码里,可以通过使用ajax来修改全局变量的值:其中async:false是把ajax从异步改为同步,这样就可以实现在方法里实现对全局变量的修改。<scripttype=”text/javascript”>varn=1;functionchangen(){$.ajax({async:false,

    2022年5月3日
    55
  • 雷达系统设计及matlab仿真(一) 第一章 雷达基础知识概论(测距 距离分辨率 多普勒频率 雷达方程 噪声和信噪比 脉冲积累)

    雷达系统设计及matlab仿真(一) 第一章 雷达基础知识概论(测距 距离分辨率 多普勒频率 雷达方程 噪声和信噪比 脉冲积累)1.雷达基础知识了解2.雷达测距最大不模糊距离3.距离分辨率4.多普勒频率‘5.雷达方程噪声和信噪比6.搜索(警戒)7.脉冲积累相干积累与非相干积累8.雷达损失

    2022年5月4日
    75
  • [奶奶看了都会]京东自动签到薅羊毛-完整教程

    [奶奶看了都会]京东自动签到薅羊毛-完整教程又到了节假日的时间了,每逢节假日必须得搞事情。最近北京疫情管的比较严,楼主去小区旁边的小公园散步,都要出示核酸证明了。。。上一次说到用脚本完成京东自动签到领京豆:[奶奶看了都会]教你用脚本薅京东签到羊毛这个只能领到自动签到任务的豆子而已,还有好多京豆任务都没做了,导致咱白白损失了一波豆豆?所以今天嘛,我们就把京豆的任务都做一遍,把京豆全给领了?手机抓包为了获取到京豆签到的接口,需要在手机京东APP上抓包,这就需要用到手机抓包的技术了楼主对着网上的教程实践了一波,搞了一整天之后,得到的结论是An

    2025年11月25日
    3
  • java基础编程入门教程,2022最新

    java基础编程入门教程,2022最新Java学习到什么程度可以找第一份工作自己买了本Java从入门到精通。以为可以很快地学完,非CS专业。现在我想说所有系列的从入门到精通都是垃圾,一年多来,我每天白天看视频,晚上敲代码到凌晨,我是一个很倔的人,我认为天下没有任何东西是人类学不会的,所以我就付出高三一样的时间去学习。为你解读Java三大框架其实作为Java初学者除了简单的学习框架本身,还需要思考更多的东西,比如有框架和没有框架到底给你带来了什么?用Struts,要充分的理解MVC思想,用Hibernate,要明白什么是持久化,什么是OR/m

    2022年7月9日
    19
  • 数组的splice方法和slice方法_splice方法返回值

    数组的splice方法和slice方法_splice方法返回值功能强大的splice方法数组中最强大的方法splice(),可以对数组进行添加、删除、替换操作删除arr=[‘0赵’,‘1钱’,‘2孙’,‘3李’,‘4周’,‘5吴’]arr.splice(index,num)第一个参数表示开始删除的索引位置,num表示删除的个数如arr.splice(1,2)返回的结果为:arr=[‘0赵’,‘3李’,‘4周’,‘5吴’]添加arr=[‘0赵’,‘1钱’,‘2孙’,‘5吴’]arr.splice(index,0,‘x’,‘y’)第一个参数表示

    2022年9月25日
    3
  • 30分钟看懂经济运行原理_看懂了自然哲学原理

    30分钟看懂经济运行原理_看懂了自然哲学原理这部分内容主要解释一些概念和术语,最好是先理解这部分内容。公钥密码体制分为三个部分,公钥、私钥、加密解密算法,它的加密解密过程如下:加密:通过加密算法和公钥对内容(或者说明文)进行加密,得到密文。

    2022年8月4日
    9

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号