V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
eightqueen
V2EX  ›  Java

Java 的 log4j2 怎么按级别输出到不同文件?

  •  
  •   eightqueen · 2018-05-13 21:55:14 +08:00 · 1894 次点击
    这是一个创建于 2174 天前的主题,其中的信息可能已经有所发展或是发生改变。

    我希望所有 error 日志都打到 error.log 文件里,所以设定最顶层的 logger(com.baidu)日志级别为 error,子包(比如 com.baidu.trace )级别为 info,但是子包的 error 日志始终无法打到 error.log 里,而是和 info 日志一起打到子包配置的文件里。

    vjnjc
        1
    vjnjc  
       2018-05-14 01:27:34 +08:00 via Android
    我也想知道😂
    zhantss
        2
    zhantss  
       2018-05-14 03:48:52 +08:00
    log4j 实现每一个等级的 Threshold 是按照优先级的包含关系确定写入文件的,比如 info 包含了 error 等
    你需要控制写入文件的话需要自己实现一个 Appender,主要重写的方法是 isAsSevereAsThreshold,改成相同而不是 equals,默认返回还是 true
    具体看这两段代码
    https://github.com/apache/log4j/blob/trunk/src/main/java/org/apache/log4j/AppenderSkeleton.java#L218
    https://github.com/apache/log4j/blob/trunk/src/main/java/org/apache/log4j/Priority.java#L123
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   我们的愿景   ·   实用小工具   ·   5570 人在线   最高记录 6543   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 32ms · UTC 02:46 · PVG 10:46 · LAX 19:46 · JFK 22:46
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.