Loading [MathJax]/jax/output/CommonHTML/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >线上问题排查 | 动态修改LOGGER日志级别

线上问题排查 | 动态修改LOGGER日志级别

原创
作者头像
蛮三刀酱
修改于 2020-11-13 01:54:01
修改于 2020-11-13 01:54:01
2.3K0
举报

前言

大多数情况下,我们会在打印日志时定义日志的LOGGER级别,用来控制输出的信息范围。

一方面,过多的输出会影响查看日志的效率,另一方面,过少的日志让问题定位变得困难。

但当线上出现问题时,线上容器通常定义在info级别,发生一些疑难问题时,光靠info级别的日志很难定位问题。

一个典型的场景:在一些需要打印MySQL语句的场景,如果你正在使用MyBatis框架,由于MyBaits中SQL语句是DEBUG级别的信息,通常在线上容器就没法看到。

一个丑陋的解决办法就是在沙箱/预发环境,将log4j.xml中的info改为debug:

代码语言:txt
AI代码解释
复制
<Root level="info">
    <AppenderRef ref="detail"/>
    <AppenderRef level="error" ref="error"/>
</Root>

然后重新打包部署,再发起请求来调试代码。

甚至在一些无法模拟请求的场景下,还需要将修改灰度至线上环境,大量的debug信息会对线上服务造成实质性的影响。

本文简要介绍如何使用开源Java调试工具Arthas,实时修改线上服务的LOGGER级别,从而免去打包再部署的繁杂手续,更快的定位线上问题。

效果演示:

在这里插入图片描述
在这里插入图片描述

本文内容重点:

  • Arthas工具简介
  • 本地测试:实时修改LOGGER级别
  • 线上实战:实时打印MyBatis SQL语句
  • 总结

本文阅读大概需要:2分钟

码字不易,欢迎关注我的个人原创技术公众号:后端技术漫谈(二维码见文章底部)

Arthas工具简介

Arthas是开源的Java诊断工具,它的功能可以大致参考下图:

它运行的原理是通过字节码生成工具(ASM字节码增强),将代理逻辑编织到原来的类里,实现对应的监控调试等功能。

关于Arthas这个工具,之前我写了一篇完整的总结文章,包括所有功能的使用和原理初探,可以去原文章查看:https://juejin.im/post/6844903998730797070

本地测试:实时修改LOGGER级别

安装arthas

网络安装

在接通外网的环境下,可以使用快速网络安装,会从源拉全量包。

代码语言:txt
AI代码解释
复制
curl -O https://arthas.aliyun.com/arthas-boot.jar
java -jar arthas-boot.jar

全量安装

如果本地外网环境不通,比如某些容器内是不允许外网访问的,那么可以使用预先下载好的全量安装包,然后解压后运行包内的jar,使用命令:

代码语言:txt
AI代码解释
复制
java -jar arthas-boot.jar

启动arthas

我在本地启动arthas,效果如下图:

全局Logger信息

使用命令:

代码语言:txt
AI代码解释
复制
logger

可以看到所有logger的信息,包括其中每个appenders。

使用如下命令,修改名称为ROOT的logger的日志级别至debug级别:

代码语言:txt
AI代码解释
复制
logger --name ROOT --level debug

可以看到多出了debug级别的输出。

指定类名的logger信息

在有多个logger的情况下,可以查找指定名称的logger

代码语言:txt
AI代码解释
复制
logger -n ROOT

指定classloader的logger信息

如果需要改变指定类的输出级别,先要定位到该类的classLoader,然后修改该clasLoader的logger。

使用sc命令查看你需要改变的类信息:

代码语言:txt
AI代码解释
复制
sc -d cn.monitor4all.miaoshaweb.DynamicLoggerTest | grep classLoaderHash

随后可以通过classLoader找到其对应的logger:

代码语言:txt
AI代码解释
复制
logger -c 18b4aac2

然后就可以调整对应的logger日志级别:

代码语言:txt
AI代码解释
复制
logger -c 18b4aac2 --name ROOT --level debug

使用 ongl 命令

此外,Arthas还支持使用ognl来修改日志级别。但是这种方法对log4j不友好,修改会报错。并且就算支持的logback/slf4j,也需要复杂的形如ognl -c @org.slf4j.LoggerFactory@getLogger("root").setLevel()的命令才能修改,并不是一个很好的办法。

线上实战:实时打印MyBatis SQL语句

容器内启动arthas

我的线上容器,是没有外网访问权限的(这种情况蛮常见的),我将全量包解压在容器内运行:

打印DEBUG级别的SQL日志

下图是没有DEBUG信息的一条请求日志,可以看到只有入参出参的拦截器信息(INFO级别):

使用logger --name ROOT --level debug,将SQL语句输出出来:

毕竟,很多时候线上的bug是不小心拼错SQL导致。

总结

文章简单总结了使用Arthas来动态调整日志级别的使用方法。在线上环境,能够有效的提升排查问题的效率。当然Arthas能做的还远不止于此,更多有趣并且实用的功能等待大家的发掘。

参考

关注我

我是一名奋斗在一线的互联网后端开发工程师。

主要关注后端开发,数据安全边缘计算等方向,欢迎交流。

各大平台都可以找到我

原创文章主要内容

  • 后端开发实战
  • Java面试
  • 设计模式/数据结构/算法题解
  • 读书笔记/逸闻趣事/游戏人生

个人公众号:后端技术漫谈

如果文章对你有帮助,不妨点赞,收藏起来~

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
Java线上问题排查神器Arthas快速上手与原理浅谈
以前,你碰到这些问题,解决的办法大多是,修改代码,重新上线。但是在大公司里,上线的流程是非常繁琐的,如果为了多加一行日志而重新发布版本,无疑是非常折腾人的。
Java3y
2019/11/18
7160
arthas命令logger动态修改日志级别--视频演示
arthas命令logger主要是用来处理日志记录相关的功能,包括查看logger和appenders信息,包括classloader,日志level,codeSource,日志文件名等等。其中最有用的就是修改logger的级别,这个功能可以在不重启JVM的情况下,打开debug调试日常,在完成排查之后,再修改为正常的info级别,对于线上排查问题来讲,非常有帮助。当然有用的前提是,日志规范执行到位,如果开发压根没有输出debug日志,那就无能为力了,不过这难不倒arthas,还会有更牛的命令来实现这个功能,以后我会继续分享演示视频。
FunTester
2020/05/06
1.3K0
使用arthas在线调整日志级别
十毛
2023/10/16
6500
深入剖析:如何使用Pulsar和Arthas高效排查消息队列延迟问题
根据之前的经验来看,要么是业务消费逻辑出现问题导致消费过慢,当然也有小概率是消息队列的 Bug(我们使用的是 pulsar)。
crossoverJie
2024/04/30
2680
深入剖析:如何使用Pulsar和Arthas高效排查消息队列延迟问题
线上 JVM 调优工具 Athars 入门
Arthas 是一款线上监控诊断产品,通过全局视角实时查看应用 load、内存、gc、线程的状态信息,并能在不修改应用代码的情况下,对业务问题进行诊断,包括查看方法调用的出入参、异常,监测方法执行耗时,类加载信息等,大大提升线上问题排查效率。
用户3587585
2024/04/17
5020
线上 JVM 调优工具 Athars 入门
线上问题排查神器 Arthas
之前介绍过 BTrace,线上问题排查神器 BTrace 的使用,也说它是线上问题排查神器。都是神器,但今天这个也很厉害,是不是更厉害不好说,但是使用起来非常简单。如果你用 BTrace 的话,需要事先写好探测脚本,然后上传到需要排查问题的服务器,然后执行命令。比方说获取某个方法的参数、返回值、异常等。而 Athas 方便在不用写脚本,直接用命令行方式就可以,使用它就好像在用安装在服务器上的各种工具一样,比如 top、jps、jmap 等。
古时的风筝
2019/09/29
7730
线上问题排查神器 Arthas
排查是什么意思_nacos有了为什么要用dubbo
Apache Dubbo是Alibaba开源的高性能RPC框架,在国内有非常多的用户。
全栈程序员站长
2022/08/04
4060
Java 诊断工具 Arthas 常见命令使用和实战(排查函数调用异常、热更新、调用方法函数、查看堆栈调用等)
云原生这么多微服务,当然需要一个诊断利器来排查问题。 Arthas 是阿里开源的 Java 诊断工具,深受开发者喜爱。在线排查问题,无需重启;动态跟踪 Java 代码;实时监控 JVM 状态。Arthas 支持 JDK 6+,支持 Linux/Mac/Windows,采用命令行交互模式,同时提供丰富的 Tab 自动补全功能,进一步方便进行问题的定位和诊断。
共饮一杯无
2022/11/28
3.6K0
Java 诊断工具 Arthas 常见命令使用和实战(排查函数调用异常、热更新、调用方法函数、查看堆栈调用等)
当Dubbo遇上Arthas:排查问题的实践
Arthas是Alibaba开源的应用诊断利器,9月份开源以来,Github Star数三个月超过6000。
kirito-moe
2019/11/05
6260
【Arthas】实战教程
最近团队在研究线上问题排查方式,发现线上存在CPU飙升问题,测试环境无法复现,查阅资料发现 Arthas 能够分析此类问题。
后端码匠
2023/11/05
6740
Alibaba开源Java诊断工具Arthas简单介绍
Arthas 是Alibaba开源的Java诊断工具,深受开发者喜爱。在线排查问题,无需重启;动态跟踪Java代码;实时监控JVM状态。
yuanfan2012
2020/07/23
9400
Alibaba开源Java诊断工具Arthas简单介绍
学会 Arthas,让你 3 年经验掌握 5 年功力
Arthas 是Alibaba开源的Java诊断工具,动态跟踪Java代码;实时监控JVM状态,可以在不中断程序执行的情况下轻松完成JVM相关问题排查工作 。支持JDK 6+,支持Linux/Mac/Windows。这个工具真的很好用,而且入门超简单,十分推荐。
爱撸猫的杰
2022/09/21
6500
线上应用诊断与调试利器——Arthas
Java 诊断利器 Arthas,是阿里的一款开源工具。Github-alibaba/arthas 上可以看到它的介绍。
yuanyi928
2020/11/09
8860
线上应用诊断与调试利器——Arthas
记一次线上日志堆栈不打印问题排查(附:高并发系统日志打印方案可收藏)
线上的报错 error 日志不打印详细的堆栈信息了.本着追根到底的精神.仔细排查了下.目前的日志打印过程.系统和代码虽然是公司的,解决问题都是自己的呀.
用户6256742
2024/06/28
5400
记一次线上日志堆栈不打印问题排查(附:高并发系统日志打印方案可收藏)
学会 arthas,让你 3 年经验掌握 5 年功力!
点击上方“芋道源码”,选择“设为星标” 管她前浪,还是后浪? 能浪的浪,才是好浪! 每天 10:33 更新文章,每天掉亿点点头发... 源码精品专栏 原创 | Java 2021 超神之路,很肝~ 中文详细注释的开源项目 RPC 框架 Dubbo 源码解析 网络应用框架 Netty 源码解析 消息中间件 RocketMQ 源码解析 数据库中间件 Sharding-JDBC 和 MyCAT 源码解析 作业调度中间件 Elastic-Job 源码解析 分布式事务中间件 TCC-Transaction
芋道源码
2022/08/29
4790
学会 arthas,让你 3 年经验掌握 5 年功力!
Github Action 快速上手指南
Github之前更新了一个Action功能(应该是很久以前了),可以实现很多自动化操作。用来替代用户自己设置的自动化脚本(比如:钩子+Jenkins)。
蛮三刀酱
2021/02/20
8250
【开源实战】Canal生产环境部署常见问题分析
Canal是开源的数据库Binlog日志解析框架,主要用途是基于 MySQL 数据库增量日志解析,提供增量数据订阅和消费。
蛮三刀酱
2020/06/11
1.8K0
线上问题排查思路、工具小结
本文总结了一些常见的线上应急现象和对应排查步骤和工具。分享的主要目的是想让对线上问题接触少的同学有个预先认知,免得在遇到实际问题时手忙脚乱。
公众号 IT老哥
2020/10/09
3.3K0
线上问题排查思路、工具小结
【线上排查实战】AOP切面执行顺序你真的了解吗
公司这两个月启动了全新的项目,项目排期满满当当,不过该学习还是要学习。这不,给公司搭项目的时候,踩到了一个Spring AOP的坑。
蛮三刀酱
2020/10/21
1.6K0
Arthas 链路追踪笔记
Arthas 是一款线上监控诊断产品,通过全局视角实时查看应用 load、内存、gc、线程的状态信息,并能在不修改应用代码的情况下,对业务问题进行诊断,包括查看方法调用的出入参、异常,监测方法执行耗时,类加载信息等,大大提升线上问题排查效率。
时光_赌徒
2023/11/28
3940
推荐阅读
相关推荐
Java线上问题排查神器Arthas快速上手与原理浅谈
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档