1.Arthas 源码阅读
2.Java 诊断工具 Arthas 常见命令(超详细实战教程)
3.InetAddress.getLocalHost() 执行很慢?
4.Arthas使用指南
5.美了哭了,修改修改AduSkin是源码我见过最好看的WPF开源控件库
6.实战Arthas:常见命令与最佳实践
Arthas 源码阅读
Arthas源码阅读的核心逻辑主要集中在arthas-agent的启动流程中,首先通过java -jar arthas-core.jar执行,代码然后Bootstrap获取Instrumentation并进行初始化。修改修改Server启动后,源码通过TelnetClient发送命令到Server,代码仿豆瓣源码python由CommandResolver解析并执行,修改修改如thread命令的源码执行过程。
在启动阶段,代码用户输入会被TelnetConsole接收并由ShellServer解析,修改修改通过TermServerTermHandler处理,源码包括常用的代码HttpTelnetTermServer和HttpTermServer(基于Netty)。例如,修改修改ThreadCommand的源码process方法负责处理thread命令的具体逻辑。
获取JVM信息通过JvmCommand,代码Watch接口通过EnhancerCommand实现,利用字节码增强技术(如EnhanceWatchAdviceListener)收集方法运行时信息。Profiler逻辑则涉及一个二进制工具,具体使用方法可参考相关文档。
在实际问题解决上,Arthas提供了两种操作方式:一是通过命令行选项--command指定多条命令,适用于非持续监控场景;二是利用HTTP API进行远程控制,如Arthas Tunnel,适用于需要动态控制进程的场景,如管理多个Agent。
此外,深入理解Consumer的completionHandler,如Termd Demo中的ReadLine部分,有助于更好地掌握Arthas的交互机制。
Java 诊断工具 Arthas 常见命令(超详细实战教程)
在云原生环境中,拒绝给公司源码微服务众多,一个高效的诊断工具Arthas对于问题排查至关重要。Arthas,由阿里开源,深受开发者喜爱,其在线诊断功能无需重启服务,支持动态追踪Java代码和实时监控JVM状态,适用于JDK 6+平台,采用命令行交互模式,具备Tab补全功能,方便定位问题。 Arthas官方定位为Java应用诊断神器,GitHub上已有超过.4K颗星的赞誉。它的功能丰富,如查看线程、内存、GC状态,分析入参/返回值/异常,快速定位热点,生成火焰图等,对解决疑难问题大有裨益。本文将深入介绍Arthas的常见命令应用。启动示例与诊断工具
首先,通过下载并运行arthas-demo.jar启动案例程序,然后启动诊断工具Arthas-boot.jar。诊断工具操作流程
启动Arthas-boot后,它会列出所有Java进程,用户选择需要诊断的进程,比如输入1并回车。好用的视频源码成功Attach后,会显示Arthas LOGO,并通过输入help获取命令帮助。实时数据监控与系统操作
通过dashboard命令,你可以查看CPU、内存、GC和运行环境等实时数据。只需输入q或Ctrl+C退出dashboard。具体命令功能
- thread命令:打印线程ID及其栈信息,如thread 1 | grep 'main('。
- sc和sm命令:sc用于查看已加载类,sm用于查找类的具体函数,支持-d参数详细查看。
- jad命令:用于反编译代码,可指定源代码输出。
- ognl命令:动态执行代码,支持返回值展开和多行表达式。
- watch命令:查看函数参数、返回值、异常信息,支持条件表达式和异常捕获。
- sysprop和jvm命令:获取系统和JVM信息。
- reset命令:重置增强类,清除Arthas的字节码增强。
实操案例与异常排查
遇到函数调用异常时,Arthas能帮助查看详细请求参数和堆栈。例如,通过watch命令追踪UserController的参数和异常。
其他功能
- 修改应用Logger Level,卡片消息生成源码可以使用ognl获取和设置。
- 热更新代码,如修改UserController逻辑。
- 利用tt命令获取Spring Context并调用函数。
- 跟踪HTTP请求过滤器,找出 Unauthorized的源头。
每个命令都有详细的文档支持,可根据具体需求灵活运用。更多高级功能如查看线程、CPU使用率和调用栈,请参考相关教程以充分利用Arthas的强大功能。
InetAddress.getLocalHost() 执行很慢?
某次在 SpringBoot 2.2.0 项目中,引入了代码导致项目启动明显变慢,并触发了相关警告信息。信息显示,获取主机信息耗时超过阈值毫秒。如果为Mac系统,则会提示在/etc/hosts文件中配置本地DNS。通过查看hosts文件,发现添加了主机名后,警告信息消失。这引发了对获取主机信息机制的探究。
为了解决问题,首先尝试更改hosts文件内容,并使用sudo killall -HUP mDNSResponder 刷新DNS,避免重启电脑。再次启动程序后,警告信息消失,表明主机信息获取耗时未超过毫秒。abs函数指标源码
接下来,通过Wireshark抓包观察网络行为。在本地回环网络中,选择了Loopback网络接口。在没有添加主机名时,发现主机信息获取耗时较长,经过三次请求后返回结果。添加主机名后,程序直接读取hosts文件获取主机名,无需网络交互。
为了深入了解过程,查看了对应的源码。在没有添加主机名时,时间主要耗在InetAddress.getAddressesFromNameService方法中。进一步跟踪发现,调用链路耗时主要集中在nameService.lookupAllHostAddr方法。深入到native方法后,查阅了jdk源码。发现实际的实现涉及与操作系统的交互。
通过在Java项目中直接输入主机名,对比hosts文件中添加或未添加主机名的情况,发现未添加时无法找到网络地址,而添加后能返回本地IP地址.0.0.1。这说明系统对标准Linux代码进行了修改,加入了本地缓存、重试和超时机制,以优化主机名获取过程。
总结,本文通过使用多种技术手段研究了Java中获取主机名慢的问题,包括Wireshark抓包、Arthas工具定位性能瓶颈、查看jdk源码等,揭示了主机名获取的原理及优化机制。进一步研究时,可能需要验证本地缓存、重试和超时等机制的详细实现。参考文章提供了一些查找和分析相关技术细节的途径,有助于深入理解问题。
Arthas使用指南
Arthas是一个强大的Java工具,提供了丰富的功能以帮助开发者诊断和调试。它的命令行工具集包括dashboard、thread、watch、trace、monitor等,覆盖了从线程监控、方法调用跟踪到性能分析和代码热部署的各个环节。下面是一些关键命令的简要介绍:
- **dashboard**:实时展示当前系统中线程的详细信息,包括线程ID、名称、优先级、状态、CPU使用率和运行时间等。
- **thread**:查看和分析JVM中所有线程,支持筛选高CPU消耗线程,查找死锁,以及查看线程池信息。
- **watch**:实时观测方法的输入输出和异常,帮助你追踪执行过程中的细节。
- **trace**:追踪方法调用路径,记录每个节点的耗时,便于性能瓶颈定位。
- **monitor**:定期统计指定方法的执行情况,便于监控和优化。
- **jad**:反编译已加载类的源码,对代码进行深入分析。
- **stack**:查看方法的调用链,帮助理解调用关系。
- **tt**:方法调用的时空隧道,记录每次调用的参数和返回值,便于长期观测和回溯。
- **retransform** 和 **redefine**:热部署功能,允许动态修改类的代码,但需注意修改限制和注意事项。
- **quit** 和 **shutdown**:分别用于退出当前客户端和关闭Arthas服务器,其中retransform的结果会保留。
使用Arthas时,请确保理解每个命令的用途,并根据需要灵活运用,以提高开发效率。
美了哭了,AduSkin是我见过最好看的WPF开源控件库
一款简单漂亮的WPF UI,融合部分开源框架的组件,为个人定制的UI,可供学者参考。原链接:dotnet9.com/.html
追求极致,永臻完美,AduSkin控件库应运而生。
1.关于`AduSkin`
AduSkin集成了HandyControl、Arthas、WPF.UI等开源C# WPF控件库,加上了控件库作者的特色。
1.1 控件库全貌
1.2 动态修改主题色
1.3 技术交流
Nuget搜索AduSkin,可直接导入使用,具体使用方法请参考AduSkin.Demo。
作者QQ:
QQ技术交流群:
AduSkin源码:AduSkin
2.基于AduSkin控件库衍生的Case案例
多个实例展示了如何利用AduSkin创建应用,包括AduShopping、AduChat、心理FM、SuperEvil、HttpTool等。
3. AduSkin的特色控件组合案例
包括个控件组合案例,如Win菜单、导航容器、多功能Tab、过渡容器、轮播容器、时间轴、视频控件、树形菜单、数据列表、右侧弹窗、右侧弹出菜单等。
代码支持自定义设置,如视频播放间隔时间。
4. 写在最后的话
使用AduSkin控件库后,需解压视频解析库“libvlc.7z”至Demo输出目录,视频播放功能才能正常运作。
欢迎使用AduSkin控件库,有任何问题,可添加作者QQ号或加入QQ技术交流群进行交流。
实战Arthas:常见命令与最佳实践
本文深入介绍实战 Arthas 的常见命令与最佳实践,帮助开发者更高效地进行 Java 应用程序的诊断和调优。推荐关注 Arthas 官方文档与 Arthas Idea 插件,以加速学习与问题排查。以下是常用命令详解与使用技巧:
类命令:getstatic 用于查看类的静态属性,推荐使用 ognl 命令以获取更灵活的交互方式。
jad 命令反编译指定已加载类的源码,适用于快速验证代码是否生效。retransform 命令则用于加载外部 .class 文件,重新编译已有类,但需谨慎使用,以免影响程序稳定性。
监测排查命令包括:monitor 实现方法执行监控,stack 输出当前方法调用路径,thread 显示当前线程信息,trace 显示方法内部调用路径及耗时,trace 命令尤其适用于性能问题定位,而 tt 命令则记录方法调用的详细信息。
JVM 监控命令有:heapdump 生成堆转储文件,jfr 集成 Java Flight Recorder 收集诊断数据,memory 查看 JVM 内存信息,dashboard 实时显示系统数据,classloader 列出所有 classloader 信息,logger 查看 logger 信息,sc 查看已加载类,mbean 显示 MBean 信息,profiler 生成应用热点火焰图,vmoption 查看和更新 VM 参数,vmtool 利用 JVMTI 接口实现内存对象查询和强制 GC。
特殊命令中,-v 用于查看匹配表达式的执行结果,ognl 命令灵活执行 OGNL 表达式,options 为全局开关,help 查看命令帮助,history 列出命令历史,cls 清屏,quit 退出 Arthas。
快捷键及实用功能:使用 OGNL 语言简化表达式过滤,支持管道命令进行进一步筛选,后台异步执行检测命令,实现问题排查的灵活性。
Arthas 强大的功能和灵活性为开发者提供了强大的工具,帮助提高诊断和调优效率。探索更多 Arthas 的用法与功能,将有助于提升开发工作的便利性和效率。
arthas常ç¨å½ä»¤
æ§è¡æåå, arthasæä¾äºä¸ç§å½ä»¤è¡æ¹å¼ç交äºæ¹å¼, arthasä¼æ£æµå½åæå¡å¨ä¸çJavaiç¨,并å°è¿ç¨å表å±ç¤ºåºæ¥,ç¨æ·è¾å ¥å¯¹åºçç¼å·(1.2.3.4.)è¿è¡éæ©,ç¶åå车ãæ¹å¼1:
æ¹å¼2:è¿è¡æ¶éæ©Javaè¿ç¨PID
quit
éè¿å¾ä¸çthreadåºåå¯ä»¥çåºå½åå ç¨cpuæé«ç两个æ¯jvmå é¨çº¿ç¨
Java 8ä¹åæ¯æè·åJVMå é¨çº¿ç¨CPUæ¶é´ï¼è¿äºçº¿ç¨åªæå称åCPUæ¶é´ï¼æ²¡æIDåç¶æçä¿¡æ¯ï¼æ¾ç¤ºID为-1ï¼ã éè¿å é¨çº¿ç¨å¯ä»¥è§æµå°JVMæ´»å¨ï¼å¦GCãJITç¼è¯çå ç¨CPUæ åµï¼æ¹ä¾¿äºè§£JVMæ´ä½è¿è¡ç¶åµã
JVMå é¨çº¿ç¨å æ¬ä¸é¢å ç§ï¼
注æï¼çº¿ç¨æ 为第äºéæ ·ç»ææ¶è·åï¼ä¸è½è¡¨æéæ ·é´éæ¶é´å 该线ç¨é½æ¯å¨å¤çç¸åçä»»å¡ã建议é´éæ¶é´ä¸è¦å¤ªé¿ï¼å¯è½é´éæ¶é´è¶å¤§è¶ä¸åç¡®ã å¯ä»¥æ ¹æ®å ·ä½æ åµå°è¯æå®ä¸åçé´éæ¶é´ï¼è§å¯è¾åºç»æã
é»è®¤æç §CPUå¢éæ¶é´éåºæåï¼åªæ¾ç¤ºç¬¬ä¸é¡µæ°æ®ï¼é»è®¤æç §CPUå¢éæ¶é´éåºæåã
æ¾ç¤ºææå¹é 线ç¨ä¿¡æ¯ï¼ææ¶éè¦è·åå ¨é¨JVMç线ç¨æ°æ®è¿è¡åæã
thread -b, æ¾åºå½åé»å¡å ¶ä»çº¿ç¨ç线ç¨
æ¾å°é»å¡å ¶ä»çº¿ç¨ç线ç¨ï¼å³å½åå ç¨éç线ç¨
注æï¼ ç®ååªæ¯ææ¾åºsynchronizedå ³é®åé»å¡ä½ç线ç¨ï¼ å¦ææ¯ java.util.concurrent.Lock ï¼ ç®åè¿ä¸æ¯æã
thread -i : ç»è®¡æè¿mså ç线ç¨CPUæ¶é´ã
thread -n 3 -i : ååºmså æå¿ç3个线ç¨æ
âSearch-Classâ çç®åï¼è¿ä¸ªå½ä»¤è½æç´¢åºææå·²ç»å è½½å° JVM ä¸ç Class ä¿¡æ¯ï¼è¿ä¸ªå½ä»¤æ¯æçåæ°æ [d] ã [E] ã [f] å [x:] ã
âSearch-Methodâ çç®åï¼è¿ä¸ªå½ä»¤è½æç´¢åºææå·²ç»å è½½äº Class ä¿¡æ¯çæ¹æ³ä¿¡æ¯ã
sm å½ä»¤åªè½çå°ç±å½åç±»æ声æ (declaring) çæ¹æ³ï¼ç¶ç±»åæ æ³çå°ã
scç类信æ¯ï¼små¯ä»¥çç±»çæ¹æ³ä¿¡æ¯ï¼ä¸¤è æ£å¥½å¯ä»¥ç»åè æ¥çã
java -jar arthas-boot.jar --tunnel-server ws://...:/ws
help æ¥çå½ä»¤å¸®å©ä¿¡æ¯
cls æ¸ ç©ºå½åå±å¹åºå
session æ¥çå½åä¼è¯çä¿¡æ¯
reset éç½®å¢å¼ºç±»ï¼å°è¢« Arthas å¢å¼ºè¿çç±»å ¨é¨è¿åï¼Arthas æå¡ç«¯å ³éæ¶ä¼éç½®ææå¢å¼ºè¿çç±»
version è¾åºå½åç®æ Java è¿ç¨æå è½½ç Arthas çæ¬å·
history æå°å½ä»¤åå²
quit éåºå½å Arthas 客æ·ç«¯ï¼å ¶ä» Arthas 客æ·ç«¯ä¸åå½±å
stop å ³é Arthas æå¡ç«¯ï¼ææ Arthas 客æ·ç«¯å ¨é¨éåº
keymap Arthaså¿«æ·é®å表åèªå®ä¹å¿«æ·é®
dashboard å½åç³»ç»çå®æ¶æ°æ®é¢æ¿
thread æ¥çå½å JVM ç线ç¨å æ ä¿¡æ¯
watch æ¹æ³æ§è¡æ°æ®è§æµ
trace æ¹æ³å é¨è°ç¨è·¯å¾ï¼å¹¶è¾åºæ¹æ³è·¯å¾ä¸çæ¯ä¸ªèç¹ä¸èæ¶
stack è¾åºå½åæ¹æ³è¢«è°ç¨çè°ç¨è·¯å¾
tt æ¹æ³æ§è¡æ°æ®çæ¶ç©ºé§éï¼è®°å½ä¸æå®æ¹æ³æ¯æ¬¡è°ç¨çå ¥ååè¿åä¿¡æ¯ï¼å¹¶è½å¯¹è¿äºä¸åçæ¶é´ä¸è°ç¨è¿è¡è§æµ
monitor æ¹æ³æ§è¡çæ§
jvm æ¥çå½å JVM ä¿¡æ¯
vmoption æ¥çï¼æ´æ° JVM è¯æç¸å ³çåæ°
sc æ¥ç JVM å·²å è½½ç类信æ¯
sm æ¥çå·²å 载类çæ¹æ³ä¿¡æ¯
jad åç¼è¯æå®å·²å 载类çæºç
classloader æ¥ç classloader ç继æ¿æ ï¼urlsï¼ç±»å 载信æ¯
heapdump 类似 jmap å½ä»¤ç heap dump åè½