Arthas 入门到实战(四)arhtas idea plugin集成插件

news2025/2/22 0:53:01

前言:

Arthas 官方的工具还不够足够的简单,需要记住一些命令,但是我们需要的是一个能够简单处理字符串信息的插件即可使用。当在处理线上问题的时候需要最快速、最便捷的命令,因此插件还是有存在的意义和价值的。

一、idea插件安装

1. idea中安装 arthas idea 插件

2. idae安装RestfulTool插件

3. 下载测试项目与arthas包并启动。

测试项目下载地址:GitHub - WangJi92/arthas-plugin-demo: Arthas idea plugin 体验demo,可以直接体验一下 一些高级的功能 ,调用spring static context 方法、获取 spring 环境变量优先级信息等等

本地下载 arthas包并启动。

二、使用arthas插件操作命令

1. 使用 Watch 查看方法返回值

在idea方法中右击,选择 Arthas Command ---> Watch ,点击后,自动复制

在 cmd中粘贴

[arthas@7720]$ watch com.wangji92.arthas.plugin.demo.controller.CommonController userOgnlX '{params,returnObj,throwExp}'  -n 5  -x 3
Press Q or Ctrl+C to abort.
Affect(class count: 1 , method count: 1) cost in 124 ms, listenerId: 1

在idea中利用 Restfull Toot 插件请求该方法:

查看

[arthas@7720]$ watch com.wangji92.arthas.plugin.demo.controller.CommonController userOgnlX '{params,returnObj,throwExp}'  -n 5  -x 3
Press Q or Ctrl+C to abort.
Affect(class count: 1 , method count: 1) cost in 124 ms, listenerId: 1
method=com.wangji92.arthas.plugin.demo.controller.CommonController.userOgnlX location=AtExit
ts=2023-01-22 21:10:15; [cost=0.3504ms] result=@ArrayList[
    @Object[][isEmpty=true;size=0],
    @ArrayList[
        @ArrayList[
            @User[User{name='fan-Copy', age=28}],
            @User[User{name='null', age=null}],
        ],
    ],
    null,
]

 2. 使用 trace 查看调用链路信息

[arthas@7720]$ trace com.wangji92.arthas.plugin.demo.controller.CommonController traceE  -n 5 --skipJDKMethod false
Press Q or Ctrl+C to abort.
Affect(class count: 1 , method count: 1) cost in 30 ms, listenerId: 2
`---ts=2023-01-22 21:14:46;thread_name=http-nio-8080-exec-6;id=30;is_daemon=true;priority=5;TCCL=org.springframework.boot.web.embedded.tomcat.TomcatEmbeddedWebappClassLoader@64c74c4a
    `---[1008.7126ms] com.wangji92.arthas.plugin.demo.controller.CommonController:traceE()
        +---[0.01% 0.0619ms ] org.springframework.util.StringUtils:isEmpty() #104
        +---[0.00% 0.0055ms ] java.lang.StringBuilder:<init>() #107
        +---[0.00% min=0.0024ms,max=0.0063ms,total=0.0087ms,count=2] java.lang.StringBuilder:append() #107
        +---[0.00% 0.0038ms ] java.lang.StringBuilder:toString() #107
        `---[99.98% 1008.5265ms ] com.wangji92.arthas.plugin.demo.service.ArthasTestService:doTraceE() #109

 如果想要其子级也显示,可以设置:

 

 

trace -E com.wangji92.arthas.plugin.demo.controller.CommonController|com.wangji92.arthas.plugin.demo.service.ArthasTestService traceE|doTraceE -n 5  --skipJDKMethod false '1==1'
Press Q or Ctrl+C to abort.
Affect(class count: 3 , method count: 2) cost in 83 ms, listenerId: 5
`---ts=2023-01-22 21:22:19;thread_name=http-nio-8080-exec-2;id=2c;is_daemon=true;priority=5;TCCL=org.springframework.boot.web.embedded.tomcat.TomcatEmbeddedWebappClassLoader@64c74c4a
    `---[1009.1685ms] com.wangji92.arthas.plugin.demo.controller.CommonController:traceE()
        +---[0.00% 0.0147ms ] org.springframework.util.StringUtils:isEmpty() #104
        +---[0.00% 0.0074ms ] java.lang.StringBuilder:<init>() #107
        +---[0.00% min=0.004ms,max=0.0093ms,total=0.0133ms,count=2] java.lang.StringBuilder:append() #107
        +---[0.00% 0.007ms ] java.lang.StringBuilder:toString() #107
        `---[99.98% 1009.0153ms ] com.wangji92.arthas.plugin.demo.service.ArthasTestService:doTraceE() #109
            `---[99.99% 1008.9555ms ] com.wangji92.arthas.plugin.demo.service.impl.ArthasTestServiceImpl:doTraceE()
                +---[99.91% 1008.0273ms ] java.lang.Thread:sleep() #19
                +---[0.01% 0.0575ms ] org.springframework.util.StringUtils:isEmpty() #21
                +---[0.00% 0.0171ms ] java.lang.StringBuilder:<init>() #25
                +---[0.00% 0.0166ms ] java.lang.Thread:currentThread() #25
                +---[0.00% 0.0159ms ] java.lang.Thread:getName() #25
                +---[0.00% min=0.0041ms,max=0.0153ms,total=0.0194ms,count=2] java.lang.StringBuilder:append() #25
                `---[0.01% 0.0883ms ] java.lang.StringBuilder:toString() #25

其他命令使用请看官方文档:arthas idea plugin 使用文档 (yuque.com)

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Blender 粒子系统

文章目录简介.添加粒子系统.属性.自发光&#xff08;发射&#xff09;.源.烘焙(仅发射体).速度(仅发射体).旋转(仅发射体&#xff0c;除非毛发系统开启了高级属性).物理(仅发射体).毛发动力学(仅毛发).渲染.路径.视图显示.子级.簇集.糙度.扭结.力场权重.顶点组.粒子编辑.渲染毛…

GraalVM和Spring Native尝鲜,一步步让Springboot启动飞起来,66ms完成启动

简介 GraalVM是高性能的JDK&#xff0c;支持Java/Python/JavaScript等语言。它可以让Java变成二进制文件来执行&#xff0c;让程序在任何地方运行更快。这或许是Java与Go的一场战争&#xff1f; 下载安装GraalVM 安装GraalVM 首先到官网下载&#xff0c;我是直接到GitHub Re…

7-2输入/输出系统-I/O方式

文章目录一.程序查询方式二.程序中断方式三.DMA方式1.传送过程2.DMA控制器&#xff08;DMAC&#xff09;的内部结构3.DMA传送方式&#xff08;1&#xff09;停止CPU访问主存&#xff08;2&#xff09;DMA与CPU交替访存&#xff08;3&#xff09;周期挪用/周期窃取4.DMA方式的特…

基于改进粒子群算法的混合储能系统容量优化(Matlab代码实现)

&#x1f4a5;&#x1f4a5;&#x1f49e;&#x1f49e;欢迎来到本博客❤️❤️&#x1f4a5;&#x1f4a5; &#x1f3c6;博主优势&#xff1a;&#x1f31e;&#x1f31e;&#x1f31e;博客内容尽量做到思维缜密&#xff0c;逻辑清晰&#xff0c;为了方便读者。 ⛳️座右铭&a…

css特性(继承、层叠、优先级)

1、继承性 特性: 子元素有默认继承父元素样式的特点(子承父业) 可以继承的常见属性(文字控制属性都可以继承) colorfont-style、 font-weight、 font-size、 font-familytext-indent、text-align、line-height … 注意点: 控制字的都能继承 可以通过调试工具判断样式是否可以…

应用系统基于CAS实现单点登录的解决方案

单点登录 (SingleSign-On&#xff0c;SSO) &#xff0c;是一种帮助用户快捷访问网络中多个站点的安全通信技术。单点登录系统基于一种安全的通信协议&#xff0c;该协议通过多个系统之间的用户身份信息的交换来实现单点登录。使用单点登录系统时&#xff0c;用户只需要登录一次…

JAVA的PDF Viewer:Big Faceless PDF Viewer Crack

PDF Viewer是一个可以显示PDF文档的Swing组件。针对不需要完整 API 的客户&#xff0c;Viewer 可以作为 Applet、应用程序或通过 Java Web Start 安装&#xff0c;或嵌入到 Swing 应用程序中。 产品概览 打印、保存、文本搜索、表单、数字签名和注释是众多可用功能中的一部分 -…

IB 课程的挑战(二)

以下我想换个角度用自身的经历以及多年来教学的经验去分享修读 IB课程的挑战。 &#xff08;一&#xff09;必修文学科2022尽管我于会考中文获得「A」级成绩&#xff0c;但面对IB课程的中国文学 (IB Chinese A Literature)时&#xff0c;却仍感到十分吃力。我之前从未接触过中国…

网络IO模型

1 介绍一提到网络IO&#xff0c;甚至一些网络框架&#xff0c;就无法避免遇到阻塞、非阻塞、同步、异步的概念&#xff0c;要理解这些概念&#xff0c;先要清楚网络IO是什么&#xff0c;以及网络IO如何工作。网络IO本质上也是IO的一种&#xff0c;就是数据的输入输出&#xff0…

护网行动(防守方)linux服务器通用安全加固指南(1)

实验所属系列&#xff1a;Linux服务器搭建/Linux服务安全 Linux 是一个开放式系统&#xff0c;可以在网络上找到许多现成的程序和工具&#xff0c;这既方便了用户&#xff0c;也方便了黑客&#xff0c;因为他们也能很容易地找到程序和工具来潜入 Linux 系统&#xff0c;或者盗…

CnOpenData中国观鸟记录数据

一、数据简介 观鸟&#xff0c;是指在自然环境中利用望远镜等观测记录设备在不影响野生鸟类正常生活的前提下观察鸟类的一种科学性质的户外活动。 鸟类&#xff0c;是生物多样性中最具指示性的类群。由全国各地观鸟爱好者们共同记录的观鸟信息&#xff0c;能够展示中国各地区的…

cesium +vue3 +vite 实现点线面功能

第一步&#xff1a;搭建vue3项目 1、npm在相应文件夹下创建 npm create vitelatest2、选择项目名称 3、选择vue 4、选择是否使用typescript 或者JavaScript 5、记得在终端npm install一下就可以启动项目了 第二步&#xff1a;引入cesiumJS 1、npm引入 npm i cesium vite…

海康Visionmaster-VM2D,VM3D,VM深度学习对电脑配置要求

为确保VM算法平台能正常安装及运行&#xff0c;对PC配置有所要求。 第一&#xff1a;推荐配置&#xff1a; 操作系统&#xff1a;Windows7/10&#xff08;64位中文操作系统&#xff09; CPU&#xff1a;Intel Core i7-6700 3.4GHz 或以上&#xff08;如需使用CPU相关深度学习…

32岁面试字节软件测试岗,想不到居然这么简单......

前段时间有个在小公司干了七八年的朋友离职了&#xff0c;想要拼一拼大厂&#xff0c;于是他选择了字节跳动。面试总共花费了 20 天左右&#xff0c;包含了 4 轮电话面试、1 轮笔试、1 轮主管视频面试、1 轮hr视频面试。 据他了解到的信息&#xff0c;其实去字节面试的人很多&…

爬虫(一)爬虫基本概念

爬虫概念网络爬虫 (网页蜘蛛, 网络机器人)爬虫就是模拟客户端发送网络请求, 接受请求对应的响应, 一种按照一定的规则,自动地抓取互联网信息的程序。理论上来说, 只要是用户通过客户端(浏览器)能够做到事情, 爬虫都能够去做。爬虫: 模拟客户端访问, 抓取数据。反爬: 保护重要数…

3、边界值分析

如何选定边界值 很难提供一份如何进行边界值分析的“详细说明”&#xff0c;因为这种方法需要一定程度的创造性&#xff0c;以及对问题采取一定程度的特殊处理办法。 但是可以提供一些通用指南&#xff1a; 如果输入条件规定了一个输入值范围&#xff0c;那么应针对范围的边…

WY49 数对

【答案解析】&#xff1a; 暴力破解&#xff1a;将 x 和 y 分别遍历 [1, n] &#xff0c;进行判断当 x % y > k 时统计计数 count 即可,但是这样的话当 n 的值非常大 的时候循环次数将非常恐怖&#xff0c;需要循环 n^2 次。 更优解法&#xff1a; 假设输入 n10 , k3 &#…

QT/C++——对话框

一、标准对话框 #include "widget.h" #include <QVBoxLayout> #include <QHBoxLayout>Widget::Widget(QWidget *parent): QWidget(parent) {btcolor new QPushButton("setcolor");bterrm new QPushButton("errmsg");btfile new …

检索业务:构建结果数据与分析

明确返回的结果对象数据 结果对象 Data public class SearchResult {/*** 查到的所商品信息*/private List<SkuEsModel> products;private Integer pageNum;//当前页面private Long total;//总记录数private Integer totalPages;//总页码private List<CatalogVo&g…

linux安装python3.10.9

Linux系统安装python3.10.9Linux系统安装python3.10.9查看系统自带python信息python官网下载安装包解压安装包上传安装包到服务器解压安装包进入解压后的目录安装python使用的依赖安装python使用的依赖完成编译安装python设置软连接设置python软连接设置pip软连接配置环境变量使…