不停机不更新代码线上调试BUG的工具
如果你有以下痛点,请你查看本文章:
1、我改的代码为什么没有执行到?难道是我没 commit?分支搞错了?
2、遇到问题无法在线上 debug,难道只能通过加日志再重新发布吗?
3、线上遇到某个用户的数据处理有问题,但线上同样无法 debug,线下无法重现!
4、是否有一个全局视角来查看系统的运行状况?
5、有什么办法可以监控到JVM的实时运行状态?
6、怎么快速定位应用的热点,生成火焰图?
Arthas-解决以上所有问题
一、快速启动,(我的第一给demo)
1、下载git代码,本地启动app应用
演示的源码
package com.eujian.arthaslearn.controller;
import com.fasterxml.jackson.databind.node.ObjectNode;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
@RequestMapping
@RestController
public class ArthasController {
@GetMapping("/arthasGet")
public String arthasGet(String a,String b){
    System.out.println("arthasGet");
    System.out.println(String.format("a=%s,b=%s",a,b));
    return a;
}
@GetMapping("/arthasTrace")
public String arthasTrace() throws InterruptedException {
    Thread.sleep(100);
    new MyService().send();
    return "arthasTrace";
}
@PostMapping("/arthasInvote")
public ObjectNode arthasInvote(@RequestBody ObjectNode objectNode){
    System.out.println("arthasInvote");
    System.out.println(String.format("objectNode=%s",objectNode));
    return objectNode;
}
}
package com.eujian.arthaslearn.controller;
public class MyService {
public String send(){
    System.out.println("send被调用了");
    try {
        Thread.sleep(1000);
    } catch (InterruptedException e) {
        e.printStackTrace();
    }
    return "send";
}
}
github地址:xxxx
gitlab地址:xxx
启动应用
java -jar ./target/arthas-learn-1.0.0.jar
2、下载arthas的jar包(linux命令)
curl -O https://alibaba.github.io/arthas/arthas-boot.jar
java -jar arthas-boot.jar
运行arthas结果
选择1然后回车
3、 查看dashboard
输入dashboard,按回车/enter,会展示当前进程的信息,按ctrl+c可以中断执行。
dashboard
4、通过thread命令来获取到app线程
通过thread 2获取线程id为1的线程
thread命令
5、通过jad来反编译Main Class
jad com.eujian.arthaslearn.controller.ArthasController
jad结果
6、watch某个函数的入参和出参
输入命令watch com.eujian.arthaslearn.controller.ArthasController arthasGet '{params[0],params[1],returnObj}'
用来监听ArthasController这个类的arthasGet方法
访问接口 curl localhost:8085/arthasGet?a=heetget&b=saas
监听结果
watch命令
7、trace命令 输出方法路径上的每个节点上耗时
输入 trace com.eujian.arthaslearn.controller.ArthasController arthasTrace
另外另个终端输入curl localhost:8085/arthasTrace
trace命令
不停机不更新代码线上调试BUG的工具的更多相关文章
- 线上调试bug
		在以往的工作中,线上一有bug,就需要把文件弄到本地来改,但经常会碰见本地环境又和线上不一样,导致调试困难,闭着眼睛改好之后传到线上去看对不对,不对的话又要改,循环往复,要多麻烦就有多麻烦啊. 今天给 ... 
- 分享下使用 svn,测试服务器代码自动更新、线上服务器代码手动更新的配置经验
		分享下使用 svn,测试服务器代码自动更新.线上服务器代码手动更新的配置经验 利用SVN的POST-COMMIT钩子自动部署代码 Linux SVN 命令详解 Linux SVN 命令详解2 使用sv ... 
- 测试老司机都在用的表白神器你会吗?-Fiddler之AutoResponse线上调试
		一.Fiddler在线调试功能和表白神器介绍  在以往的工作中,线上有bug,就需要把文件弄到本地来改,但经常会碰见本地环境又和线上不一样,导致调试困难,闭着眼睛改好之后传到线上去看对不对,不对的话 ... 
- 关于线上的bug什么时候修复的思考
		这里系统专门指的是那种用户量大的系统,比如有几百万或者上千万的注册会员.因为小系统因为用户量少,不存在这种思考,考虑有时候是多余的.另外还有内部系统,给自己公司内部人员使用的,即便是出现了问题,也不会 ... 
- 线上出bug了?别怕,这么定位!
		摘要: Source Map还是很神奇的. 原文:线上出bug了?别怕,这么定位! 公众号:前端小苑 Fundebug经授权转载并修改,版权归原作者所有. 工作中,生产环境代码是编译后代码,搜集到报错 ... 
- 被产品经理怼了,线上出Bug为啥你不知道
		前言 前几天跟读者聊天,他说被产品经理给怼了.原因是线上出 Bug 了,最后是客户反馈才知道的. 我就问他:你们是不是没做监控? 读者:我们是刚成立的创业团队,目前最重要的就是堆功能,很多基础设施都没 ... 
- 一个线上程序bug,由通用补数程序引起
		下游发现接口可用率非100%,马上线上查看,发现数据在有些情况下通用补数的数据是空, 有20%的用户是没有相应偏好等的数据的,需要通用补数来补数,结果通用补数没有数据. 通用补数数据的检查报警时必须要 ... 
- 调试工具-fiddler:本地资源替换线上调试
		Fiddler是一个http协议调试代理工具,它能够记录并检查所有你的电脑和互联网之间的http通讯,设置断点,查看所有的“进出”Fiddler的数据(指cookie,html,js,css等文件,这 ... 
- svn利用钩子post-commit自动更新到线上测试服务器(测试中未验证)
		创建一个新的版本库: [root@centos03 svn]# pwd /home/svn [root@centos03 svn]# svnadmin create webtest [root@cen ... 
随机推荐
- 【代码审计】PHP代码审计---基础记录
			PHP伪协议 PHP伪协议事实上是其支持的协议与封装协议,支持的种类有以下12种. * file:// - 访问本地文件系统 * http:// - 访问 HTTP(s) 网址 * ftp:// - ... 
- Camera插件之CinematicCamera介绍
			Camera插件之CinematicCamera 继承自PerspectiveCame 构造函数引用的PerspectiveCamera的构造函数, 代码如下 var CinematicCamera ... 
- [Docker]linux异常关机,docker镜像丢失
			在运行中的docker容器遇到意外情况,可能会自动终止运行,例如磁盘空间不足. 解决办法: 找到/var/lib/docker/containers文件夹下的所有容器ID 执行命令,查看容器信息 ,找 ... 
- intelliJ 软件项目打开运行
			1.导入项目 2.首先更改数据库,找到application-dev.yml文件,更改数据源 3.配置tomcat端口 找到application.yml 文件 然后打开pom.xml 更改版本号 ... 
- 【贪心算法】HDU 5747 Aaronson
			题目大意 vjudge链接 给你一个n,m,求解满足等式x0+2x1+4x2+...+2mxm=n的x0~xm的最小和(xi为非负整数) 数据范围 0≤n,m≤109 思路 n和m都在int范围内,所 ... 
- hugo官方相关文档地址
			+++ date="2020-10-17" title="hugo官方相关文档地址" tags=["hugo"] categories=[& ... 
- php长时间的脚本,报502
			php-fpm超时时间设置request_terminate_timeout分析原创loophome 最后发布于2017-11-22 16:17:59 阅读数 21201 收藏展开今天发现了一个很神奇 ... 
- subprocess中命令为参数序列和字符串的区别
			参数args 参数args可以是一个参数序列,也可以是一个单独的字符串.参数序列通常是首选的,因为它允许模块处理参数的转义和引号(例如,允许文件名中有空格). 如果传递参数序列,默认情况下,程序执行序 ... 
- Linux命令行bash的快捷键
			提升效率 锁屏 Ctrl + s 敲什么命令没反应,但是敲上去了,屏幕上不做任何反应 Ctrl + q 再解锁 例如: 先Ctrl + s 锁屏 然后在命令行敲入 [root@C8-1 ~]# rm ... 
- python第一章:基础
			1.数学操作符: 数学操作符与数学基本类似 最高级:** 第二级:*././/.% 第三级:+ .- 遵循从左到右的顺序 如果想改变优先级 可以使用括号,比如:(3+2)*(5-4)=5*1=5 2. ... 
