log4j多线程日志输出混乱

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

变成图片描述

这样

阅读 9.6k
2 个回答

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

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

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题