JVM-接口响应时间很长解决办法

问题
在程序运行过程中,发现有几个接口的响应时间特别长,需要快速定位到是哪一个方法的代码执行过程中出现了性能问题。
解决思路
已经确定是某个接口性能出现了问题,但是由于方法嵌套比较深,需要借助于算法定位到具体的方法。

Arthas的trace命令

使用arthas的trace命令,可以展示出整个方法的调用路径以及每一个方法的执行耗时。

命令: trace 类名 方法名

添加--skipJDKMethod false 参数可以输出JDK核心包中的方法及耗时。

添加 ‘ #cost >毫秒值 ’ 参数,只会显示耗时超过该毫秒值的调用。

添加 -n 数值参数,最多显示该数值条数的数据。

所有监控都结束之后,输入stop结束监控,重置arthas增强的对象。(arthas底层使用动态代理的方式去增强这些对象从而获取他的调用时间,这样就增加了方法调用的开销降低了性能,如果不输入stop,增强的对象会在内存中保存,这个性能将会持续产生,所以最好是使用stop结束监控)

Arthas使用trace命令统计每个方法的执行时间

在这里插入图片描述

代码:

package com.itheima.jvmoptimize.performance;

import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

import java.util.ArrayList;
import java.util.Random;

@RestController
@RequestMapping("/performance")
public class PerformanceController {

    private Object obj1 = new Object();
    private Object obj2 = new Object();
    private Random random = new Random();

    @GetMapping("/1")
    public void test1(){
        while (true){

        }
    }

    @GetMapping("/deadlock1")
    public String test2() throws InterruptedException {
        synchronized (obj1){
            Thread.sleep(5000);
            synchronized (obj2){
                return "返回成功";
            }
        }
    }

    @GetMapping("/deadlock2")
    public String test3() throws InterruptedException {
        synchronized (obj2){
            Thread.sleep(5000);
            synchronized (obj1){
                return "返回成功";
            }
        }
    }

    @GetMapping("/slow")
    public void test4(int i) throws InterruptedException {
        if(i <= 0){
            return;
        }
        Thread.sleep(random.nextInt(2000));
        test5();
    }

    private void test5() throws InterruptedException {
        Thread.sleep(random.nextInt(1000));
    }


    @GetMapping("/profile1")
    public void test6() throws InterruptedException {
        ArrayList<Integer> objects = new ArrayList<>();
        for (Integer i = 0; i < 20000000; i++) {
            objects.add(i);
        }
    }

    @GetMapping("/profile2")
    public void test7() throws InterruptedException {
        ArrayList<Integer> objects = new ArrayList<>(20000000);
        for (Integer i = 0; i < 20000000; i++) {
            objects.add(i);
        }
    }

}

启动程序(springboot)

启动arthas连接springboot应用程序(可自行百度查找):

输入命令进行监控慢请求的接口

trace com.itheima.jvmoptimize.performance.PerformanceController test4

打开测试软件请求:

http://localhost:8882/performance/slow?i=1

在这里插入图片描述

请求结果如下发现可以打印出请求比较慢的一些接口和信息

在这里插入图片描述

也可以使用命令查看更详细的显示

trace com.itheima.jvmoptimize.performance.PerformanceController test4 --skipJDKMethod false

在这里插入图片描述

再次使用postman发起请求

输出内容为:

在这里插入图片描述
可以看出命令窗口中输出了详细的方法和内容

重新发送请求将 i=1改为i=0(这样代码直接就return出去了)

发起请求 http://localhost:8882/performance/slow?i=0

在这里插入图片描述

可以发现依旧能打印出来信息

在这里插入图片描述

但是在线上环境这种端时间的请求我们不希望被arthas监控到,我们可以加个参数根据耗时时间打印出来内容

命令:

 trace com.itheima.jvmoptimize.performance.PerformanceController test4 --skipJDKMethod false  '#cost >1000'

再次发起请求
在这里插入图片描述

可以发现什么都没有打印出来

在这里插入图片描述

将参数改成i=1发现请求时间超过1s
在这里插入图片描述

在这里插入图片描述

如上图已经打印出来信息了

接下来可以输入-n 设置监控多少次请求

trace com.itheima.jvmoptimize.performance.PerformanceController test4 -n 1

在这里插入图片描述

打开postman发起两次请求看下结果:
在这里插入图片描述
在这里插入图片描述

命令窗口内容如下

在这里插入图片描述

会发现当前命令自动退出了,我们可以对它进行仔细分析

注意:arhtas 有一个小细节如下

启动一个项目,其中有个接口循环100w次
在这里插入图片描述

请求后发现接口响应时长为1.5秒:
在这里插入图片描述

我们启动arthas监控一下这个接口,在命令提示行输入命令
在这里插入图片描述

再次调用发现这个接口耗时增加到了2秒多
在这里插入图片描述

将代码中的循环调整为100次再次使用arthas监控

在这里插入图片描述在这里插入图片描述

这个现象表现是arthas对循环较大的接口会产生较大的影响,循环越大影响响应时间越长,建议本地测试时适当减少循环次数

使用完记得输入stop命令进行关闭,这样将不会当前的内存和性能产生任何影响
在这里插入图片描述

watch命令

在使用trace定位到性能较低的方法之后,

使用watch命令监控该方法,可以获得更为详细的方法信息。

命令:watch 类名 方法名 '{params, returnobj}' '#cost>毫秒值' -x 2

'{params,returnobj}' 代表打印参数和返回值
-x 代表打印的结果中如果有嵌套(比如对象里有属性),最多只展开2层。允许设置的最大值为4。

测试如下
在这里插入图片描述
在这里插入图片描述

总结

1、通过arthas的trace命令,首先找到性能较差的具体方法,如果访问量比较大,建议设置最小的耗时,精确的找到耗时比较高的调用。
2、通过watch命令,查看此调用的参数和返回值,重点是参数,这样就可以在开发环境或者测试环境模拟类似的现象,通过debug找到具体的问题根源。
。允许设置的最大值为4。

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Sui主网升级至V1.15.1版本

升级要点 Sui协议版本升至&#xff1a;32 #15080: 自己转移给自己的linter将不会在没有store能力的对象上触发&#xff0c;因此将生成较少的警告消息。为了避免冗余&#xff0c;还缩短了linter警告消息的长度。 #15096: 当给定对象的字段来自coin模块但不是Coin本身时&…

【rabbitMQ】springboot整合rabbitMQ模拟简单收发消息

目录 1.创建项目和模块 2.添加rabbitMQ依赖 3.启动rabbitMQ服务 4.引入rabbitMQ服务端信息 5.通过单元测试模拟业务发送消息 6. 接收消息 1.创建项目和模块 2.添加rabbitMQ依赖 <!-- rabbitmq依赖--> <dependency> <groupId>org.sp…

PCIe设备热插拔-理论篇

硬件层面理解热插拔 PRSNT1#和PRSNT2#信号与PCIe设备的热插拔相关。在基于PCIe总线的Add-in 卡中&#xff0c;PRSNT1# 和PRSNT2#信号直接相连&#xff0c;而在处理器主板中&#xff0c;PRSNT1#信号接地&#xff0c;而PRSNT2#信号通过上 拉电阻接为高。 不同的处理器系统处理PC…

刘家窑中医医院鲁卫星主任:冬季守护心脑血管,为社区居民送去健康关爱

随着冬季的来临&#xff0c;气温逐渐降低&#xff0c;心脑血管疾病的风险也随之增加。为了提高公众对心脑血管疾病的认知和预防意识&#xff0c;北京刘家窑中医医院于近日成功举办了冬季守护心脑血管公益义诊活动。 本次义诊活动主要针对社区居民中的中老年人&#xff0c;特别是…

微服务技术 RabbitMQ SpringAMQP P61-P76

B站学习视频https://www.bilibili.com/video/BV1LQ4y127n4?p61&vd_source8665d6da33d4e2277ca40f03210fe53a 文档资料: 链接&#xff1a;https://pan.baidu.com/s/1P_Ag1BYiPaF52EI19A0YRw?pwdd03r 提取码&#xff1a;d03r 一 初始MQ 1. 同步通讯 2. 异步通讯 3. MQ常…

聊聊Api接口优化的几个方法!

我负责的系统到2021年初完成了功能上的建设&#xff0c;开始进入到推广阶段。随着推广的逐步深入&#xff0c;收到了很多好评的同时也收到了很多对性能的吐槽。刚刚收到吐槽的时候&#xff0c;我们的心情是这样的&#xff1a; 当越来越多对性能的吐槽反馈到我们这里的时候&…

《对话品牌》——科技与时尚的融合

本期节目《对话品牌》栏目组邀请到了江西先禾服饰有限公司董事长吁火兰女士参加栏目录制&#xff0c;分享其企业故事&#xff0c;树立品牌形象&#xff0c;提升品牌价值&#xff01; 节目嘉宾&#xff1a;吁火兰 节目主持人&#xff1a;杨楠 节目播出平台&#xff1a;中央新…

MagicAnimate:Temporally consistent human image animation using diffusion model

1.Introduction 本文研究了任务形象动画人物&#xff0c;旨在根据特定的运动序列生成一个具有特定参考身份的视频。现有的人物图像动画的数据驱动方法可以基于所使用的生成主干模型分为两类&#xff0c;1.基于GAN&#xff0c;通常使用变形函数将参考图变形为目标姿态&#xff0…

AnimateAnything:Fine-grained open domain image animation with motion guidance

1.Introduction 本文旨在借助视频扩散模型的motion prior来解决开放领域图像动画问题&#xff0c;提出了一种可控扩散图像动画方法&#xff0c;能够在保留细节的同时对图像中的任意对象进行动画处理。为了增强用户对动画过程的控制能力&#xff0c;引入了motion area guidance和…

kafka支持外网访问

kafka支持外网访问 1.kafka正常部署之后如果不修改&#xff0c;外网是无法访问的&#xff0c;具体如下&#xff08;这里是单节点&#xff09; 2.这个时候需要修改kafka的config中的server.properties中的 listeners 修改为0.0.0.0 监控所有网卡&#xff0c;advertised.listene…

汽车软件大时代,如何提升软件工程创新力?

当前&#xff0c;传统汽车产业正加速数字化转型&#xff0c;“软件定义汽车”不断深化。在电动化、智能化和网联化趋势下&#xff0c;汽车软件已经成为汽车技术革新和发展的核心驱动力之一。根据亿欧智库发布的《2023中国智能电动汽车车载软件市场分析报告》&#xff0c;2022年…

Leetcode—783.二叉搜索树节点最小距离【简单】

2023每日刷题&#xff08;五十八&#xff09; Leetcode—783.二叉搜索树节点最小距离 实现代码 /*** Definition for a binary tree node.* struct TreeNode {* int val;* struct TreeNode *left;* struct TreeNode *right;* };*/ void dfs(struct TreeNode* roo…

为什么要用向量检索

之前写过一篇文章&#xff0c;是我个人到目前阶段的认知&#xff0c;所做的判断。我个人是做万亿级数据的搜索优化工作的。一直在关注任何和搜索相关的内容。 下一代搜索引擎会什么&#xff1f;-CSDN博客 这篇文章再来讲讲为什么要使用向量搜索。 在阅读这篇文章之前呢&#xf…

云原生之深入解析网络服务Istio、eBPF和RSocket Broker

一、服务治理 ① “服务治理”简介 在微服务时代&#xff0c;一个复杂的应用程序被分解为多个组件化、协作和连接的单元&#xff0c;服务往往会承担越来越多的业务责任&#xff0c;这使得服务治理的难度前所未有&#xff0c;仅仅依靠微服务框架级的治理是不够的&#xff0c;构…

腾讯云Elasticsearch Service产品体验

基本介绍 产品概述 腾讯云 Elasticsearch Service&#xff08;ES&#xff09;是云端全托管海量数据检索分析服务&#xff0c;拥有高性能自研内核&#xff0c;集成X-Pack。ES 支持通过自治索引、存算分离、集群巡检等特性轻松管理集群&#xff0c;也支持免运维、自动弹性、按需…

SQL进阶 | 外连接

概述 外连接的进阶用法在行列转换中比较有优势&#xff0c;往往存在需要把数据库中的格式转换成报表格式&#xff0c;但是SQL仅仅只是查询数据的语言&#xff0c;格式转换并不是原本的用途。 全外连接 标准 SQL 里定义了外连接的三种类型&#xff0c;如下所示。 左外连接&…

基于ssm生活缴费系统及相关安全技术的设计与实现论文

摘 要 互联网发展至今&#xff0c;无论是其理论还是技术都已经成熟&#xff0c;而且它广泛参与在社会中的方方面面。它让信息都可以通过网络传播&#xff0c;搭配信息管理工具可以很好地为人们提供服务。针对生活缴费信息管理混乱&#xff0c;出错率高&#xff0c;信息安全性差…

HTTP/2 快速重置 DDOS 漏洞几乎影响所有网站

一种新形式的DDOS的细节&#xff0c;它需要相对最少的资源来发起前所未有的规模的攻击&#xff0c;这使得网站成为一个明显的危险&#xff0c;因为服务器软件公司竞相发布补丁来防范它。 HTTP/2 快速重置漏洞 该漏洞利用了 HTTP/2 和 HTTP/3 网络协议&#xff0c;这些协议允许…

JavaScipt验证URL新方法(2023 年版)

JavaScript诞生以来&#xff0c;一直没有一种简单的方法验证URL&#xff0c;现在JavaScript新增了一个新方法——URL.canParse。 URL.canParse(https://www.stefanjudis.com); // true URL.canParse(www.stefanjudis.com); // falseURL.canParse() 是一种快速验证字符串是否为…

开源 Serverless 框架 Laf 性能优化实践

介绍 Laf 是一个完全开源的 Serverless 框架&#xff0c;Laf 的 Node.js 运行时容器 (以下简称为 Runtime) 是 Laf 的函数执行环境&#xff0c;依托于 Express.js 框架。采用容器进程常驻的方式&#xff0c;每一个应用对应于一个或多个容器 (弹性伸缩下)&#xff0c;底层使用了…