前面:
各位老铁们,好久没和大家见面了,最近2B哥一直躲在家里不敢出来门,过着像猪的生活.....
吃喝拉撒睡觉。远程在家办公一段时间也是遇到了比较棘手的问题。所以没有顾得上来和大家分享了,不过大家放心,2B哥从这篇文章起我又会回到正轨了(XXXX,必有后福)哈哈哈同意的点个赞哈~~~~
Arthas简介
Arthas(阿尔萨斯)是阿里巴巴开源的 Java 诊断工具,开始在淘宝内部孵化使用,后来成为阿里java项目必须使用的内部工具。2018年arthas成为ali开源项目,代码托管在github上。这是带给java系一大福音,项目深受开发者喜爱。
快速入门
目前最新版本为3.1.7,下载地址如下
启动
./as.sh 或者输入 java -jar arthas-boot.jar (推荐)
这代表当前没有java进程。那怎么办了?
官方提供了一个demo我们可以进行运行起来。
输入命令: java -jar arthash-demo.jar 是一个数学游戏的demo
源码如下:
package demo;
import java.util.ArrayList;
import java.util.List;
import java.util.Random;
import java.util.concurrent.TimeUnit;
public class MathGame {
private static Random random = new Random();
public int illegalArgumentCount = 0;
public static void main(String[] args) throws InterruptedException {
MathGame game = new MathGame();
while (true) {
game.run();
TimeUnit.SECONDS.sleep(1);
}
}
public void run() throws InterruptedException {
try {
int number = random.nextInt()/10000;
List<Integer> primeFactors = primeFactors(number);
print(number, primeFactors);
} catch (Exception e) {
System.out.println(String.format("illegalArgumentCount:%3d, ", illegalArgumentCount) + e.getMessage());
}
}
public static void print(int number, List<Integer> primeFactors) {
StringBuffer sb = new StringBuffer(number + "=");
for (int factor : primeFactors) {
sb.append(factor).append('*');
}
if (sb.charAt(sb.length() - 1) == '*') {
sb.deleteCharAt(sb.length() - 1);
}
System.out.println(sb);
}
public List<Integer> primeFactors(int number) {
if (number < 2) {
illegalArgumentCount++;
throw new IllegalArgumentException("number is: " + number + ", need >= 2");
}
List<Integer> result = new ArrayList<Integer>();
int i = 2;
while (i <= number) {
if (number % i == 0) {
result.add(i);
number = number / i;
i = 2;
} else {
i++;
}
}
return result;
}
}
这是我们在执行命令:java -jar arthas-boot.jar 就出现如下图选择自己需要查看的进程,我这儿输入1 回车,arthas就启动成功了。
web控制台
通过浏览器连接arthas
Arthas目前支持Web Console,用户在attach成功之后,可以直接访问:http://127.0.0.1:3658/。
可以填入IP,远程连接其它机器上的arthas。
总结:
安装和下载、使用还是比较简单的,大家可以自己试试,下载下来自己玩下。大家关注下我,下篇文章教大家进阶使用。比如:
Ø 这个类从哪个 jar 包加载的?为什么会报各种类相关的 Exception?
Ø 我改的代码为什么没有执行到?难道是我没 commit?分支搞错了?
Ø 遇到问题无法在线上 debug,难道只能通过加日志再重新发布吗?
Ø 线上遇到某个用户的数据处理有问题,但线上同样无法 debug,线下无法重现!
Ø 是否有一个全局视角来查看系统的运行状况?
Ø 有什么办法可以监控到JVM的实时运行状态?
这些问题大家想了解的可以关注或者点赞给2b哥哦