查看logger信息,更新logger level ### 使用参考 #### 查看所有logger信息 `logger`{{execute T2}} ```bash [arthas@2062]$ logger name ROOT class ch.qos.logback.classic.Logger classLoader org.springframework.boot.loader.LaunchedURLClassLoader@5674cd4d classLoaderHash 5674cd4d level INFO effectiveLevel INFO additivity true codeSource jar:file:/home/scrapbook/tutorial/demo-arthas-spring-boot.jar!/BOOT-INF/lib/logback-classi c-1.1.11.jar!/ appenders name CONSOLE class ch.qos.logback.core.ConsoleAppender classLoader org.springframework.boot.loader.LaunchedURLClassLoader@5674cd4d classLoaderHash 5674cd4d target System.out ... ``` #### 查看指定名字的logger信息 `logger -n org.springframework.web`{{execute T2}} ```bash [arthas@2062]$ logger -n org.springframework.web name org.springframework.web class ch.qos.logback.classic.Logger classLoader org.springframework.boot.loader.LaunchedURLClassLoader@5674cd4d classLoaderHash 5674cd4d level null effectiveLevel INFO additivity true codeSource jar:file:/home/scrapbook/tutorial/demo-arthas-spring-boot.jar!/BOOT-INF/lib/logback-classi c-1.1.11.jar!/ ``` 请记下你的classLoaderHash,后面需要使用它。在这里,它是 `5674cd4d`。 注意:请使用你的classLoaderHash值覆盖 `` ,然后手动执行下面所述命令: #### 查看指定classloader的logger信息 注意hashcode是变化的,需要先查看当前的ClassLoader信息,提取对应ClassLoader的hashcode。 如果你使用`-c`,你需要手动输入hashcode:`-c ` ```bash $ logger -c 5674cd4d ``` 对于只有唯一实例的ClassLoader可以通过`--classLoaderClass`指定class name,使用起来更加方便: `logger --classLoaderClass org.springframework.boot.loader.LaunchedURLClassLoader`{{execute T2}} ```bash [arthas@2062]$ logger --classLoaderClass org.springframework.boot.loader.LaunchedURLClassLoader name ROOT class ch.qos.logback.classic.Logger classLoader org.springframework.boot.loader.LaunchedURLClassLoader@5674cd4d classLoaderHash 5674cd4d level INFO effectiveLevel INFO additivity true codeSource jar:file:/home/scrapbook/tutorial/demo-arthas-spring-boot.jar!/BOOT-INF/lib/logback-classi c-1.1.11.jar!/ appenders name CONSOLE class ch.qos.logback.core.ConsoleAppender classLoader org.springframework.boot.loader.LaunchedURLClassLoader@5674cd4d classLoaderHash 5674cd4d target System.out ... ``` `--classLoaderClass` 的值是ClassLoader的类名,只有匹配到唯一的ClassLoader实例时才能工作,目的是方便输入通用命令,而`-c `是动态变化的。 #### 更新logger level `logger --name ROOT --level debug`{{execute T2}} ```bash [arthas@2062]$ logger --name ROOT --level debug update logger level success. ``` 注意:在教程中执行会提示错误,需要指定classloader #### 指定classloader更新 logger level 默认情况下,logger命令会在SystemClassloader下执行,如果应用是传统的`war`应用,或者spring boot fat jar启动的应用,那么需要指定classloader。 可以先用 `sc -d yourClassName` 来查看具体的 classloader hashcode,然后在更新level时指定classloader: `logger --classLoaderClass org.springframework.boot.loader.LaunchedURLClassLoader --name ROOT --level debug`{{execute T2}} ```bash [arthas@2062]$ logger --classLoaderClass org.springframework.boot.loader.LaunchedURLClassLoader --name ROOT --level debug ``` #### 查看没有appender的logger的信息 默认情况下,`logger`命令只打印有appender的logger的信息。如果想查看没有`appender`的logger的信息,可以加上参数`--include-no-appender`。 注意,通常输出结果会很长。 `logger --include-no-appender`{{execute T2}} ```bash [arthas@2062]$ logger --include-no-appender name org.thymeleaf class ch.qos.logback.classic.Logger classLoader org.springframework.boot.loader.LaunchedURLClassLoader@5674cd4d classLoaderHash 5674cd4d level null effectiveLevel INFO additivity false codeSource jar:file:/home/scrapbook/tutorial/demo-arthas-spring-boot.jar!/BOOT-INF/lib/logback-classi c-1.1.11.jar!/ appenders name DEBUG_LEVEL_REMAPPER class org.springframework.boot.logging.logback.LevelRemappingAppender classLoader org.springframework.boot.loader.LaunchedURLClassLoader@5674cd4d classLoaderHash 5674cd4d ... ```