当前位置:  开发笔记 > 编程语言 > 正文

Log4j挂起我的应用程序我做错了什么?

如何解决《Log4j挂起我的应用程序我做错了什么?》经验,为你挑选了2个好方法。

首先介绍一下应用程序的背景.我有一个应用程序通过线程池并行处理许多独立的任务.线程池现在挂起了.

以下是我的线程转储的片段,pool-2中的所有线程都被"pool-2-thread-78"阻塞.它似乎被锁定试图写入控制台,我觉得非常奇怪.任何人都可以为我阐明情况吗?

编辑:平台详细信息java版"1.6.0_07"Java(TM)SE运行时环境(版本1.6.0_07-b06)Java HotSpot(TM)客户端VM(版本10.0-b23,混合模式,共享)

Ubuntu Linux服务器双核四核机.

它似乎在写入printstream时锁定,我考虑过只删除控制台appender然而我宁愿知道它为什么阻塞并根据这些知识删除它.在过去删除,看看它是否有效已经回来咬我:)

我的log4j中的相关部分

log4j.rootLogger = DEBUG,STDOUT log4j.logger.com.blah = INFO,LOG log4j.appender.STDOUT = org.apache.log4j.ConsoleAppender log4j.appender.LOG = org.apache.log4j.FileAppender

线程转储提取

"pool-2-thread-79"Id = 149 BLOCKED org.apache.log4j.spi.RootLogger@6c3ba437由"pool-2-thread-78"Id = 148所有,位于org.apache.log4j.Category.callAppenders( Category.java:201)org.apache.log4j.Category.forcedLog(Category.java:388)atg.apache.log4j.Category.error(Category.java:302)at com.blah.MessageProcessTask.run(MessageProcessTask .java:103)at java.util.concurrent.Executors $ runnableAdapter.call(Executors.java:441)at java.util.concurrent.FutureTask $ Sync.innerRun(FutureTask/java:268)at java.util.concurrent. FutureTask.run(FutureTask/java:54)java.util.concurrent.ThreadPoolExecutor $ Worker.runTask(ThreadPoolExecutor.java:885)java.util.concurrent.ThreadPoolExecutor $ Worker.run(ThreadPoolExecutor.java:907)at java .lang.Thread.run(Thread.java:619)

java.io.FileOutputStream.write(FileOutputStream.java:260)java.io.FileOutputStream.writeBytes(Native Method)中的"pool-2-thread-78"Id = 148 RUNNABLE(BufferedOutputStream) .java:105) - 在java.io.PrintStream.write(PrintStream.java:430)上锁定<0x6f314ba4>(java.io.BufferedOutputStream) - 在org.apache上锁定<0xd5d3504>(java.io.PrintStream) .log4j.ConsoleAppender $ SystemOutStream.write(ConsoleAppender.java:173)at sun.nio.cs.StreamEncoder.writeBytes(StreamEncoder.java:202)at sun.nio.cs.StreamEncoder.implFlushBuffer(StreamEncoder.java:272)at at sun.nio.cs.StreamEncoder.implFlush(StreamEncoder.java:276)at sun.nio.cs.StreamEncoder.flush(StreamEncoder.java:122) - 在java上锁定了<0x6243a076>(java.io.OutputStreamWriter).oro.OutputStreamWriter.flush(OutputStreamWriter.java:212)org.apache.log4j.helpers.QuietWriter.flush(QuietWriter.java:57)org.apache.log4j.WriterAppender.subAppend(WriterAppender.java:315)at org .apache.log4j.WriterAppender.append(WriterAppender.java:159)atg.apache.log4j.AppenderSkeleton.doAppend(AppenderSkeleton.java:230) - 在org上锁定<0x45dbd560>(一个org.apache.log4j.ConsoleAppender). org.apache.log4j.Category.callAppenders(Category.java:203)中的apache.log4j.helpers.AppenderAttachableImpl.appendLoopOnAppenders(AppenderAttachableImpl.java:65) - 已锁定<0x6c3ba437>(org.apache.log4j.spi.RootLogger)在org.apache.log4j.Category.forcedLog(Category.java:388)org.apache.log4j.Category.error(Category.java:302)com.blah.MessageProcessTask.run(MessageProcessTask.java:103)at java.util.concurrent.Executors $ runnableAdapter.call(Executors.java:441)at java.util.concurrent.FutureTask $ Sync.innerRun(FutureTask/java:268)at java.util.concurrent.FutureTask.run (FutureTask/java:54)java.util.concurrent.ThreadPoolExecutor $ Worker.runTask(ThreadPoolExecutor.java:885)java.lang上的java.util.concurrent.ThreadPoolExecutor $ Worker.run(ThreadPoolExecutor.java:907). Thread.run(Thread.java:619)907)在java.lang.Thread.run(Thread.java:619)907)在java.lang.Thread.run(Thread.java:619)

siddhadev.. 12

您可以使用AsyncAppender更好地从记录器中分离记录器.

在Windows上,如果单击控制台窗口,这将暂停控制台,例如stdout缓冲区将填满,并且当控制台appender按顺序写入时,应用程序将挂起,直到您释放控制台(按Enter键左键).

考虑将asyncAppender与log4j一起使用 - 大部分时间都是好主意 - 唯一的问题 - AsynAppender缓冲区在退出时不会完全刷新.



1> siddhadev..:

您可以使用AsyncAppender更好地从记录器中分离记录器.

在Windows上,如果单击控制台窗口,这将暂停控制台,例如stdout缓冲区将填满,并且当控制台appender按顺序写入时,应用程序将挂起,直到您释放控制台(按Enter键左键).

考虑将asyncAppender与log4j一起使用 - 大部分时间都是好主意 - 唯一的问题 - AsynAppender缓冲区在退出时不会完全刷新.



2> 小智..:

首先,我相信log4j会串行写入文件和控制台,否则你的所有日志都会被破坏.所以当一个线程正在写另一个想要写的线程时,必须等到另一个线程完成.另外,stdout可以阻止另一端附着的东西不会耗尽它.

在unix中有一个名为stdout的特殊文件描述符.当您在控制台中启动应用程序时,stdout将附加到控制台.您还可以将stdout重定向到其他文件.例如:java Blah>/dev/null.很可能你有stdout指向一个正在填满的文件.例如,管道是一个文件,如果另一端的程序没有耗尽管道,那么写入管道的程序最终将被阻塞.

推荐阅读
赛亚兔备_393
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有