Arthas进阶

news2025/1/12 15:48:50

这里写自定义目录标题

  • 六、class和classloader
    • 6、dump
    • 7、classloader
  • ==七、monitor/watch/trace/stack等核心命令的使用==
    • 1、monitor
    • 2、watch
    • 3、trace
    • 4、stack
    • 5、tt
    • 6、option
    • 7、profiler

六、class和classloader

6、dump

将已加载类的字节码文件保存到特定目录:logs/arthas/classdump/
在这里插入图片描述

7、classloader

七、monitor/watch/trace/stack等核心命令的使用

1、monitor

monitor命令:监控指定类中方法的执行情况
用来监视一个时间段中指定方法的执行次数,成功次数,失败次数,耗时等这些信息

举例
过5秒监控一次,类demo.MathGame中primeFactors方法
monitor -c 5 demo.MathGame primeFactors
在这里插入图片描述
监控的维度说明
在这里插入图片描述

2、watch

观察到指定方法的调用情况

作用
方法执行数据观测,让你能方便的观察到指定方法的调用情况。
能观察到的范围为: 返回值 、 抛出异常 、 入参 ,通过编写OGNL 表达式进行对应变量的查看。

参数
watch 的参数比较多,主要是因为它能在 4 个不同的场景观察对象
在这里插入图片描述
这里重点要说明的是观察表达式,观察表达式的构成主要由ognl 表达式组成,所以你可以这样写 "
{params,returnObj}" ,只要是一个合法的 ognl 表达式,都能被正常支持。

举例
观察demo.MathGame类中primeFactors方法出参和返回值,结果属性遍历深度为2。
params表示所有参数数组(因为不确定是几个参数),returnObject表示返回值
watch demo.MathGame primeFactors “{params,returnObj}” -x 2
在这里插入图片描述

方法执行前进行监控
watch demo.MathGame primeFactors “{params,returnObj}” -x 2 -b
在这里插入图片描述

观察当前对象中的属性,如果想查看方法运行前后,当前对象中的属性,可以使用target关键字,代表当前对象
watch demo.MathGame primeFactors ‘target’ -x 2
在这里插入图片描述

使用target.field_name访问当前对象的某个属性
watch demo.MathGame primeFactors ‘target.illegalArgumentCount’
在这里插入图片描述

同时观察方法调用前和方法返回后,参数里-n 2,表示只执行两次。
这里输出结果中,第一次输出的是方法调用前的观察表达式的结果,第二次输出的是方法返回后的表达式
的结果
params表示参数,target表示执行方法的对象,returnObject表示返回值
watch demo.MathGame primeFactors “{params,target,returnObj}” -x 2 -b -s -n 2
在这里插入图片描述

条件表达式的例子,输出第1参数小于的情况
watch demo.MathGame primeFactors “{params[0],target}” “params[0]<0”
在这里插入图片描述

3、trace

对方法内部调用路径进行追踪,并输出方法路径上的每个节点上耗时

trace 命令能主动搜索 class-pattern / method-pattern 对应的方法调用路径,渲染和统计整个调用链路上的所有性能开销和追踪调用链路

在这里插入图片描述

举例
trace函数指定类的指定方法
trace demo.MathGame run
在这里插入图片描述

如果方法调用的次数很多,那么可以用-n参数指定捕捉结果的次数。比如下面的例子里,捕捉到一次调用
就退出命令。
trace demo.MathGame run -n 1

默认情况下,trace不会包含jdk里的函数调用,如果希望trace jdk里的函数,需要显式设置–
skipJDKMethod false。
trace --skipJDKMethod false demo.MathGame run

据调用耗时过滤,trace大于0.5ms的调用路径
trace demo.MathGame run ‘#cost > .5’
在这里插入图片描述

4、stack

输出当前方法被调用的调用路径

很多时候我们都知道一个方法被执行,但这个方法被执行的路径非常多,或者你根本就不知道这个方法是从那里被执行了,此时你需要的是 stack 命令。

举例
获取primeFactors的调用路径
stack demo.MathGame primeFactors
在这里插入图片描述

条件表达式来过滤,第0个参数的值小于0,-n表示获取2次
stack demo.MathGame primeFactors ‘params[0]<0’ -n 2

据执行时间来过滤,耗时大于0.5毫秒
stack demo.MathGame primeFactors ‘#cost>0.5’

5、tt

time-tunnel 时间隧道
记录下指定方法每次调用的入参和返回信息,并能对这些不同时间下调用的信息进行观测

在这里插入图片描述

举例
最基本的使用来说,就是记录下当前方法的每次调用环境现场。
tt -t demo.MathGame primeFactors
在这里插入图片描述
在这里插入图片描述
条件表达式
不知道大家是否有在使用过程中遇到以下困惑
- Arthas 似乎很难区分出重载的方法
- 我只需要观察特定参数,但是 tt 却全部都给我记录了下来
条件表达式也是用 OGNL 来编写,核心的判断对象依然是 Advice 对象。除了 tt 命令之外,watch 、 trace 、 stack 命令也都支持条件表达式。

解决方法重载
tt -t *Test print params.length==1

通过制定参数个数的形式解决不同的方法签名,如果参数个数一样,你还可以这样写
tt -t *Test print ‘params[1] instanceof Integer’

解决指定参数
tt -t *Test print params[0].mobile==“13989838402”

6、option

options的作用是:查看或设置arthas全局环境变量

options json-format: 获取option的值
options save-result true:设置指定的option

7、profiler

profiler 命令支持生成应用热点的火焰图。本质上是通过不断的采样,然后把收集到的采样结果生成火焰图

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

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

相关文章

49. 字母异位词分组 128. 最长连续序列

49. 字母异位词分组 128. 最长连续序列 把集合里面的所有元素都放入set容器里面 定义结果最大连续数量 ans for循环遍历每个元素 先判断集合里面有没有比这个元素小1的 如果没有 说明这个元素就是序列的第一个元素 然后接着找集合里面有没有比这个元素大1的 while一直找 …

CentOS安装htop工具

启用 EPEL Repository 安装Htop 首先启用 EPEL Repository: yum -y install epel-release启用 EPEL Repository 后, 可以用 yum 直接安裝 Htop: 安装htop yum -y install htop安装成功 输入htop使用工具 htop安装glances工具 yum install glances

pyqt字体选择器

pyqt字体选择器 pyqt字体选择器效果代码 pyqt字体选择器 pyqt中QFontDialog 类是一个预定义的对话框&#xff0c;允许用户选择一个字体并设置其样式、大小等属性。 效果 代码 from PyQt5.QtWidgets import QApplication, QWidget, QVBoxLayout, QLabel, QPushButton, QFontD…

python项目入门新手攻略

最近工作需要接手了代码量比较大的python开发的项目&#xff0c;平时写python不多&#xff0c;记录一下如何熟悉项目。 分析调用流程-pycallgraph 因为代码量比较大&#xff0c;所以希望通过工具生成代码调用流程&#xff0c;因此用到了pycallgraph。 pycallgraph&#xff0…

LiveGBS user/save 逻辑缺陷漏洞复现(CNVD-2023-72138)

0x01 产品简介 LiveGBS是安徽青柿信息科技有限公司研发的一款国标(GB28181)流媒体服务软件,可提供提供用户管理及Web可视化页面管理,开源的前端页面源码;提供设备状态管理,可实时查看设备是否掉线等信息等。 0x02 漏洞概述 LiveGBS user/save 接口处存在逻辑缺陷漏洞,未…

纯血鸿蒙APP实战开发——发布图片评论

介绍 本示例将通过发布图片评论场景&#xff0c;介绍如何使用startAbilityForResult接口拉起相机拍照&#xff0c;并获取相机返回的数据。 效果图预览 使用说明 通过startAbilityForResult接口拉起相机&#xff0c;拍照后获取图片地址。 实现思路 创建CommentData类&#…

树,二叉树的基本概念介绍,二叉树的性质

目录 树 树的定义 树的相关概念 树的存储结构 树在实际中的运用&#xff08;表示文件系统的目录树结构 &#xff09; 二叉树 二叉树的定义 现实中的二叉树 二叉树的特点 特殊的二叉树 1.斜树 2.满二叉树 3.完全二叉树 二叉树的性质 性质1&#xff1a;二叉树的第…

MyBatis(XML映射器操作)

文章目录 XML映射器操作&#xff08;XxxMapper.xml&#xff09;文件目录1.基本介绍1.优点2.常用顶级元素 2.环境配置1.在原来的父模块下创建一个子模块2.删除没用的两个文件夹3.创建基本目录4.父模块的pom.xml5.jdbc.properties6.mybatis-config.xml7.测试使用MonsterMapperTes…

芒果超媒财报解读:科技加持下,如何蜕变为内容“全科生”?

在降本增效和内容为王的基调下&#xff0c;国内头部长视频平台正在拥抱增长。 爱奇艺率先公布2023年财务数据&#xff0c;实现归母净利润19.25亿元&#xff0c;与2022年亏损1.36亿元相比&#xff0c;扭亏为盈且增幅显著。 而近日&#xff0c;随着新一季《浪姐》播出&#xff…

一文全面了解 Kaggle 平台:数据科学和机器学习的理想之地

&#x1f349; CSDN 叶庭云&#xff1a;https://yetingyun.blog.csdn.net/ 在数据科学&#xff08;Data Science&#xff09;领域&#xff0c;Kaggle 可以称得上是一座人人都想挑战的高峰。Kaggle 是一个国际知名的数据科学竞赛平台&#xff0c;由 Anthony Goldbloom 和 Ben Ha…

内网神器Cobalt Strike隐藏特征与流量混淆.

由于上次还没有写好https上线的东西&#xff0c;今天加班加点的弄出来了。 本文内容如有错误&#xff0c;望及时告知&#xff0c;以免误导他人. Cobalt Strike 特征隐藏与流量混淆 大致内容&#xff1a; 修改默认端口 服务器设置禁Ping Cobalt Strike默认证书修改 CDN隐藏…

【c++】mutable是一个关键字,用于指定一个类成员可以在一个const成员函数中被修改。

mutable是一个关键字,用于指定一个类成员可以在一个const成员函数中被修改。通常,当一个成员函数被声明为const时,这意味着这个函数不能修改它所属的对象。然而,有时候你可能需要在一个const成员函数中修改某个成员变量。这时,你就可以使用mutable关键字。webrtc的StunReq…

VOS系统录音文件REC转MP3,REC录音转WAV与WAV转MP3具体项目中实现方式,以及占用空间变化!

前面讲解了VOS3000系统的录音REC转MP3的安装步骤&#xff0c;不清楚的&#xff0c;可以移步这里查看&#xff1a;http://t.csdnimg.cn/OXNT9 或者 点击这里查看安装步骤&#xff0c;下面继续讲下他们的使用方法&#xff0c;以及实际项目中的运用&#xff0c;首先我们需要明确我…

记录一下因网络问题导致的安装Python3.8和SuperSet的报错

【报错1】Python3.8的环境报错 【背景说明】 我目前在搭建数仓最后一个环境-->将MySQL的数据用SuperSet展示&#xff0c;安装SuperSet需要提前在Linux上安装Python环境&#xff0c;下面截图就是我在创建Python3.8的环境报错 命令为&#xff1a;(base) [dahuahadoop102 ~]…

shell脚本,删除30天以前的日志,并将日志推送到nas,但运行出现/bin/bash^M。

删除30天以前的日志 将日志推送到nas中&#xff0c;然后删除pod中的日志 pod挂载到本地 运行出现/bin/bash^M 1、删除30天以前的日志&#xff1a; #! /bin/bash# 定义源日志目录 LOG_DIR/home/log/ # 删除日志 find $LOG_DIR -type f -name "*.log" -mtime 30 -exec…

沐风老师3DMAX一键生成桌子插件TableMaker使用方法

3DMAX一键生成桌子插件TableMaker使用教程 3DMAX一键生成桌子插件TableMaker&#xff0c;参数化方式快速创建各种样式桌子模型。 【适用版本】 3dMax2011-2025&#xff08;不仅限于此范围&#xff09; 【安装方法】 3DMAX一键生成桌子插件无需安装&#xff0c;使用时直接拖动…

期权交割对股市是好是坏?2024期权交割日一览表

期权交割是指期权买方在期权合约到期日或之前行使期权&#xff0c;卖方履行义务&#xff0c;按照约定的价格和数量与期权卖方进行标的物的买卖或现金结算的过程。 交割方式 期权交割可以分为实物交割和现金交割&#xff0c;具体取决于合约规定。 实物交割 实物交割是指期权买…

Git推送本地项目到gitee远程仓库

Git 是一个功能强大的分布式版本控制系统&#xff0c;它允许多人协作开发项目&#xff0c;同时有效管理代码的历史版本。开发者可以克隆一个公共仓库到本地&#xff0c;进行更改后将更新推送回服务器&#xff0c;或从服务器拉取他人更改&#xff0c;实现代码的同步和版本控制。…

C#程序带参数运行

总结参数是靠 空格来分割 不同组参数的。 参考链接 C#控制台程序入口函数 Main(string[] args) 参数详解_c#中args-CSDN博客https://blog.csdn.net/xwnxwn/article/details/113802305#:~:text%E5%8F%B3%E9%94%AE%E7%82%B9%E5%87%BB%E3%80%90%E9%A1%B9%E7%9B%AE%E3%80%91--%E3%…

下一代云原生应用引擎OpenNJet体验

文章目录 前言OpenNJet 介绍OpenNJet VS NGINXOpenNJet 安装OpenNJet 动态配置体验动态location动态黑名单动态灰度发布 体验感受 前言 作为一名技术人员&#xff0c;我们应时刻保持对行业动态的关注&#xff0c;今天我们就来体验一下号称下一代云原生应用引擎OpenNJet。 Ope…