如何以同步方式为不同的交错线程进行 Java 日志记录?



我想用例子直接解释我的问题。如果还需要其他信息,请添加注释。

我有一个小应用程序(SpringBoot+Java),它使用ThreadPool来执行多个任务。因此,假设我的池中有 2 个线程。现在,log4j用于日志记录。它将所有线程的日志写入单个文件,并且所有 2 个线程的日志数据都是交错的。

所以每个线程的工作方式都是这样的——

[Thread-1][08:15:00] entered into application
[Thread-1][08:15:00] entered method A
[Thread-1][08:15:05] exit method A
[Thread-1][08:15:10] entered method B
[Thread-1][08:15:15] exit method B
[Thread-1][08:15:30] exit from application
[Thread-2][08:15:01] entered into application
[Thread-2][08:15:01] entered method A
[Thread-2][08:15:04] exit method A
[Thread-2][08:15:11] entered method B
[Thread-2][08:15:12] exit method B
[Thread-2][08:15:22] exit from application

但是我的日志文件根据时间戳有这些条目-

[Thread-1][08:15:00] entered into application
[Thread-1][08:15:00] entered method A
[Thread-2][08:15:01] entered into application
[Thread-2][08:15:01] entered method A
[Thread-2][08:15:04] exit method A
[Thread-1][08:15:05] exit method A
[Thread-1][08:15:10] entered method B
[Thread-2][08:15:11] entered method B
[Thread-2][08:15:12] exit method B
[Thread-2][08:15:14] exit from application
[Thread-1][08:15:15] exit method B
[Thread-1][08:15:30] exit from application

我希望我的日志文件打印线程执行,而不是时间戳。我希望我的日志文件在其他线程启动之前完全打印每个线程。我怎么能做到这一点。

我已经搜索并找到了下面的文章作为最近的,但我不想要不同的日志文件- 如何在不同的日志文件中记录多个线程?

我需要将所有日志数据输出到按线程名称分组并按线程开始时间排序的单个日志文件中。

由于我猜在控制台追加器中分离日志不起作用,我建议为每个Thread定义单独的FileAppenders,就像这里描述的那样