log4j多线程日志输出混乱

log4j多线程日志输出混乱,这个怎么解决,网上说根据不同的线程,定义一个输出文件,但我想在控制台那里输出他们就是分开的
怎么将图片描述

变成图片描述

这样

回答:

要实现你想要的目的,那要打印控制台日志线程阻塞等待,比如A线程开始执行并打印日志,同时B线程也开始打印输出日志,由于A线程还没执行完,B线程输出内容要等待A线程执行完再输出,万一线程A是个长期运行线程呢? 线程B就不能打印日志了,这样的方案是万万不能接受的
妥协方法:
1 打印日志的LayoutPattern加个%t,输出线程名
2 控制台只输出特定线程
估计这两个方法 都不是题主想要的方法,等高手们看看有什么方法没

回答:

要在不影响业务的基础上实现,我目前的想法是基于BlockingQueue或其他队列解决,每次把要打印的对象组装起来放入队列。

以上是 log4j多线程日志输出混乱 的全部内容, 来源链接: utcz.com/p/168618.html

回到顶部