cmuler
V2EX  ›  Java

求助 Java 异常日志记录问题

  •  
  •   cmuler · Jul 22, 2016 · 3914 views
    This topic created in 3590 days ago, the information mentioned may be changed or developed.

    我现在在用 Java 写后台一些 restful 服务代码,整个应用程序分了多层。想问一下 ERROR 级别的日志是不是只需要在最上层记录就可以了?因为我想如果在下层的 catch 块中记录的话,可能会重复打印而导致性能问题和错误定位不清晰问题。

    5 replies    2016-07-22 11:10:49 +08:00
    BuilderQiu
        1
    BuilderQiu  
       Jul 22, 2016
    archer2ee
        2
    archer2ee  
       Jul 22, 2016 via iPhone
    异常处理一般有个原则叫早抛出,晚捕获。所以我一般都在最外层打印异常。如果最外层只用于数据封装,那么打印可移到下一层。
    angelface
        3
    angelface  
       Jul 22, 2016
    这个关键是看你怎么定位你的异常,如果你把异常定位为非预想的系统级的错误,那不用 catch ,直接不处理就好了,把正你有日志可以看,如果你把异常定位为处理业务逻辑,那一定是哪儿发生,哪儿处理。
    iyangyuan
        4
    iyangyuan  
       Jul 22, 2016 via iPhone
    底层能处理,可预料,就处理,不能处理就抛,最外层打印就行了吧,我一般在控制层打印
    tausi0661
        5
    tausi0661  
       Jul 22, 2016
    分层打印, 输出到不同的 log 文件. 但前提当然是底层只捕捉和处理它能处理的异常. 搞不定的肯定是不捕获不打印 lol
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   2559 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 36ms · UTC 15:51 · PVG 23:51 · LAX 08:51 · JFK 11:51
    ♥ Do have faith in what you're doing.