springboot日志切面使用成员变量线程不安全造成日志串数据

最近在数据库中发现日志记录有串数据的现象,通过查看代码发现,日志对象是成员变量,而spring使用的单例模式,这样会导致多线程使用一个日志对象的问题,这就是典型的线程不安全了,这样就造成了日志串数据的情况。

查找了资料,使用ThreadLocal来解决这个问题

ThreadLoal 变量,线程局部变量,同一个 ThreadLocal 所包含的对象,在不同的 Thread 中有不同的副本。这里有几点需要注意:

  • 因为每个 Thread 内有自己的实例副本,且该副本只能由当前 Thread 使用。这是也是 ThreadLocal 命名的由来。
  • 既然每个 Thread 有自己的实例副本,且其它 Thread 不可访问,那就不存在多线程间共享的问题。

ThreadLocal 提供了线程本地的实例。它与普通变量的区别在于,每个使用该变量的线程都会初始化一个完全独立的实例副本。ThreadLocal 变量通常被private static修饰。当一个线程结束时,它所使用的所有 ThreadLocal 相对的实例副本都可被回收。

总的来说,ThreadLocal 适用于每个线程需要自己独立的实例且该实例需要在多个方法中被使用,也即变量在线程间隔离而在方法或类间共享的场景。

参考:https://www.cnblogs.com/luxiaoxun/p/8744826.html

你可能感兴趣的:(java)