成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

線上排障技巧-動態修改Logger級別

開發 前端
前言大多數情況下,我們會在打印日志時定義日志的LOGGER級別,用來控制輸出的信息范圍。

[[351828]]

前言

大多數情況下,我們會在打印日志時定義日志的LOGGER級別,用來控制輸出的信息范圍。

一方面,過多的輸出會影響查看日志的效率,另一方面,過少的日志讓問題定位變得困難。

但當線上出現問題時,線上容器通常定義在info級別,發生一些疑難問題時,光靠info級別的日志很難定位問題。

一個典型的場景:在一些需要打印MySQL語句的場景,如果你正在使用MyBatis框架,由于MyBaits中SQL語句是DEBUG級別的信息,通常在線上容器就沒法看到。

一個丑陋的解決辦法就是在沙箱/預發環境,將log4j.xml中的info改為debug:

  1. <Root level="info"
  2.     <AppenderRef ref="detail"/> 
  3.     <AppenderRef level="error" ref="error"/> 
  4. </Root> 

然后重新打包部署,再發起請求來調試代碼。

甚至在一些無法模擬請求的場景下,還需要將修改灰度至線上環境,大量的debug信息會對線上服務造成實質性的影響。

「本文簡要介紹如何使用阿里巴巴開源Java調試工具Arthas,實時修改線上服務的LOGGER級別,從而免去打包再部署的繁雜手續,更快的定位線上問題。」

「效果演示:」

「本文內容重點:」

  • Arthas工具簡介
  • 本地測試:實時修改LOGGER級別
  • 線上實戰:實時打印MyBatis SQL語句
  • 總結

Arthas工具簡介Arthas是阿里開源的Java診斷工具,它的功能可以大致參考下圖:

它運行的原理是通過字節碼生成工具(ASM字節碼增強),將代理邏輯編織到原來的類里,實現對應的監控調試等功能。

關于Arthas這個工具,之前「我寫了一篇完整的總結文章」,包括所有功能的使用和原理初探,可以去原文章查看:https://juejin.im/post/6844903998730797070

本地測試:實時修改LOGGER級別

安裝arthas

網絡安裝

在接通外網的環境下,可以使用快速網絡安裝,會從阿里的源拉去全量包。

  1. curl -O https://arthas.aliyun.com/arthas-boot.jar 
  2. java -jar arthas-boot.jar 

全量安裝

如果本地外網環境不通,比如某些容器內是不允許外網訪問的,那么可以使用預先下載好的全量安裝包,然后解壓后運行包內的jar,使用命令:

  1. java -jar arthas-boot.jar 

啟動arthas我在本地啟動arthas,效果如下圖:

全局Logger信息

使用命令:

  1. logger 

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

使用如下命令,修改名稱為ROOT的logger的日志級別至debug級別:

  1. logger --name ROOT --level debug 

可以看到多出了debug級別的輸出。

指定類名的logger信息

在有多個logger的情況下,可以查找指定名稱的logger

  1. logger -n ROOT 

指定classloader的logger信息

如果需要改變指定類的輸出級別,先要定位到該類的classLoader,然后修改該clasLoader的logger。

  1. sc -d cn.monitor4all.miaoshaweb.DynamicLoggerTest | grep classLoaderHash 

使用sc命令查看你需要改變的類信息:

隨后可以通過classLoader找到其對應的logger:

  1. logger -c 18b4aac2 

然后就可以調整對應的logger日志級別:

  1. 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能做的還遠不止于此,更多有趣并且「實用」的功能等待大家的發掘。

參考

https://jueee.github.io/2020/08/2020-08-20-Arthas%E4%B9%8B%E6%9F%A5%E7%9C%8B%E5%92%8C%E4%BF%AE%E6%94%B9%E6%97%A5%E5%BF%97%E7%BA%A7%E5%88%AB/

https://arthas.aliyun.com/doc/logger.html#appenderlogger

https://juejin.im/post/6844903959195303943

本文轉載自微信公眾號「后端技術漫談」,可以通過以下二維碼關注。轉載本文請聯系后端技術漫談公眾號。

 

 

責任編輯:武曉燕 來源: 后端技術漫談
相關推薦

2011-03-28 10:03:46

Btrace

2010-09-13 11:25:16

共享無線上網

2023-01-11 08:09:25

Springboot修改日志級別

2019-03-29 10:22:08

Linux系統故障技巧

2011-07-07 14:15:35

WIFI無線

2009-04-24 16:29:51

AP共享無線上網

2009-12-23 14:30:24

WPF顯示動態GIF

2020-10-20 17:15:05

Java故障排查命令

2009-12-08 11:16:07

PHP動態圖像創建

2009-10-12 15:44:26

VB.NET動態編碼技

2010-04-14 09:38:49

Windows SerIE安全級別

2010-03-17 15:35:47

2009-07-27 10:03:02

分層模型網絡故障

2021-06-04 07:13:43

Logger TRACEDEBUG

2015-09-22 11:09:47

Java 8動態代理

2010-08-18 10:05:28

Hyper-V動態內存

2013-07-25 09:56:22

OSPF路由選擇路由故障OSPF

2021-04-27 09:22:28

鴻蒙HarmonyOS應用

2020-10-15 06:34:45

內存代碼背景頁

2010-01-20 18:51:16

VB.NET修改系統時
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 国产不卡一区在线观看 | 日韩国产免费观看 | 久久久久久国产精品免费免费狐狸 | 91高清视频在线观看 | 亚洲欧美中文日韩在线v日本 | 黄色成人亚洲 | 国产一区二区在线免费观看 | 最新日韩精品 | 久久国内 | 亚洲国产精品成人无久久精品 | 在线观看日本高清二区 | 夜夜爽99久久国产综合精品女不卡 | 97中文视频 | 国产a区 | 欧美日韩在线精品 | av国产精品 | 精品一区精品二区 | 精品欧美乱码久久久久久1区2区 | 欧美成人a| 国产精品嫩草影院精东 | 最近中文字幕免费 | 夜夜干夜夜操 | av手机免费在线观看 | 九九亚洲精品 | 亚洲精品久久久久久一区二区 | 午夜视频网站 | 欧美一区 | 视频一区二区中文字幕 | 成人福利在线视频 | 美女视频黄的免费 | 中文字幕av网站 | 美女视频网站久久 | 欧美精品久久久 | 一区二区三区免费 | 欧美一级免费看 | 91av久久久 | 视频一区二区三区中文字幕 | 国产午夜精品久久 | 亚洲欧美在线观看 | 国产精选一区 | 在线播放中文字幕 |