利用Arthas定位线上问题实例
发表于:2025-12-04 作者:千家信息网编辑
千家信息网最后更新 2025年12月04日,前言Arthas是一个类似于Btrace的JVM在线调试分析工具,具体可参考我之前写的一篇博客:利用JVM在线调试工具排查线上问题。本文分享笔者刚遇到的一个问题,虽然不复杂,但是很典型。问题与分析过程
千家信息网最后更新 2025年12月04日利用Arthas定位线上问题实例
前言
Arthas是一个类似于Btrace的JVM在线调试分析工具,具体可参考我之前写的一篇博客:利用JVM在线调试工具排查线上问题。本文分享笔者刚遇到的一个问题,虽然不复杂,但是很典型。
问题与分析过程
昨天上线遇到一个问题,交易后给大数据平台异步送数,但是他们说没收到数据,因为我们没有打日志,所以没有直接的证据证明是他们的问题而不是我们的问题。
送数的原理大致如下,就是交易主线程把数据放到队列里,然后异步线程从队列里把数据取出来,发送到后台。
队列:BlockingQueue queue = new BlockingQueue();同步线程:void sendMsg(Message msg) { queue.offer(msg);}异步线程:void consume() { Message msg = queue.take(); while(msg != null) { HttpClient.post(msg); msg = queue.take(); }} 具体送数的代码如下( 加了行数):
38 public void consume(Map msg) {39 HttpClient httpClient = new HttpClient(cm);40 PostMethod method = new PostMethod(uri);41 method.addRequestHeader("context-type", "application/x-www-form-urlencoded");42 JSONObject json = new JSONObject(msg);43 NameValuePair[] params = new NameValuePair[2];44 params[0] = new NameValuePair("topic", topic);45 params[1] = new NameValuePair("value", json.toJSONString());46 //System.out.println(msg.toString());47 logger.info("BigDataHttp Send Json:" + json.toJSONString());48 method.addParameters(params);49 try {5051 httpClient.executeMethod(method);52 if(method.getStatusCode() == 200) {53 logger.info("BigDataHttp response(Success):"+ method.getResponseBodyAsString());54 } else {55 logger.info("BigDataHttp Response(error):" + method.getResponseBodyAsString());56 }57 } catch(Exception e) {58 logger.error(e.getMessage(), e);59 } finally {60 method.releaseConnection();61 }62 }在日志里没有发现try里的异常,而比较遗憾的是,我们的日志虽然开了info级别,但是因为日志量太大,所以只开了交易上送和下发报文的日志,其他的日志都关了。
现在日志级别没法调,有没有办法能确定,请求返回了200,还是其他值呢?
可以用在线调试工具Arthas,我们使用Arthas的trace功能,查看这个类执行的详细步骤。
首先连接上这个JVM进程,pid为进程号。
java -jar arthas-boot.jar pid 然后执行命令
trace xxx.util.bigDataUtil.BigDataHttpConsumer consume这条命令的左右就是,追踪xxx.util.bigDataUtil.BigDataHttpConsumer类里consume方法的执行过程。
执行的结果如下,每一行最后的是代码行数,我们可以看一下,跟上面代码是一一对应的。
从代码中可以看到,如果返回码是200,那么它会执行第52行,如果返回码不是200,会执行55行,因此,我们通过trace功能确定执行了哪条语句,就可以知道到底返回没返回200,从结果来看,确定返回的不是200。
这样我们就有了确定的证据证明发给后台时返回非200,后台同事检查了自己的配置发现配置有误,是他们自己的问题。
问题
日志
代码
数据
线程
后台
工具
队列
交易
在线
功能
命令
就是
级别
结果
证据
过程
进程
分析
配置
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
饥荒服务器管理员命令
网络安全等级保护验收
网络安全工作个人先进事迹
腾讯云轻量服务器远程登陆不了
帮牛网络技术有限公司
电网网络安全设备升级报道
幼儿园有关网络安全的教案
关系数据库连接算法有什么
正版重庆联通服务器托管云主机
新乡闫锦网络技术有限公司
初中网络安全教育画报
人民上网守护网络安全
阻止服务器安全狗联网
dell服务器的命名
放心的制造业管理软件开发商
原神私人服务器链接
为什么要买ntp服务器 有网络
中央巡视组网络安全
网络服务器配置与管理
金蝶专业版恢复数据库
目前软件开发项目有那些
底层安全比软件开发好
服务器性能正常域名访问不了
网络技术基础考试卷
国家对网络安全方面的建设
文件地理数据库和企业地理数据库
软件开发是否需要资质证书
网络安全第一道防线视频
体验服务器
督岗心得网络安全