在日常开发中,记录业务日志是一项至关重要的任务,它有助于统计业务调用情况,方便排查错误。然而,在编写代码时出现只记录成功调用而忽略错误的情况可能是由于一些常见原因导致的。
首先,可能存在未将保存日志的代码放置在 finally
代码块中的情况。如果方法提前结束执行(比如因为异常),则可能无法到达保存日志的代码,导致错误情况未被记录。
其次,保存日志的方法可能需要单独设置事务的传播属性为 PROPAGATION_NOT_SUPPORTED
,以避免在异常发生时由于事务回滚导致已插入的数据丢失。通过设置事务的传播属性为 PROPAGATION_NOT_SUPPORTED
,可以确保日志的记录不受业务方法的事务影响,即使业务方法发生异常,日志也能够成功保存。
因此,在处理业务日志时,需要注意确保日志记录代码的执行不受业务方法执行流程的影响,并确保在异常情况下也能够正确记录错误信息,以便后续排查和处理。
@Transactional( propagation = Propagation.NOT_SUPPORTED )
为此我特地深入的了解了一下,数据库的事务传播属性。
Spring框架定义了以下几种事务的传播属性:
-
PROPAGATION_REQUIRED:如果当前没有事务,就新建一个事务;如果已经存在一个事务中,就加入该事务。这是默认的传播属性。
-
PROPAGATION_SUPPORTS:支持当前事务,如果当前没有事务,就以非事务方式执行。
-
PROPAGATION_MANDATORY:支持当前事务,如果当前没有事务,就抛出异常。
-
PROPAGATION_REQUIRES_NEW:新建一个事务,如果当前存在事务,就把当前事务挂起。
-
PROPAGATION_NOT_SUPPORTED:以非事务方式执行操作,如果当前存在事务,就把当前事务挂起。
-
PROPAGATION_NEVER:以非事务方式执行操作,如果当前存在事务,则抛出异常。
-
PROPAGATION_NESTED:如果当前存在事务,则在嵌套事务内执行。如果当前没有事务,就新建一个事务。