首先是应用程序的一些背景。我有一个应用程序通过线程池并行处理许多独立任务。线程池现在挂起。
以下是我的线程转储中的一个片段,我在 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 服务器双四核机器。
它似乎在写入打印流时被锁定,我考虑过只删除控制台附加程序,但是我宁愿知道它为什么会阻塞并根据这些知识将其删除。在过去,删除并查看它是否有效又回来咬我:)
我的 log4j 中的相关部分
log4j.rootLogger=调试,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 在 org.apache.log4j.spi.RootLogger@6c3ba437 上被阻塞,由 org.apache.log4j.Category.callAppenders 上的 "pool-2-thread-78" Id=148 拥有( Category.java:201) 在 org.apache.log4j.Category.forcedLog(Category.java:388) 在 org.apache.log4j.Category.error(Category.java:302) 在 com.blah.MessageProcessTask.run(MessageProcessTask .java:103) 在 java.util.concurrent.FutureTask$Sync.innerRun(FutureTask/java:268) 在 java.util.concurrent 的 java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:441)。 FutureTask.run(FutureTask/java:54) at java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java:885) at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:907) at java .lang.Thread.run(Thread.java:619)
"pool-2-thread-78" Id=148 在 java.io.FileOutputStream.write(FileOutputStream.java:260) 在 java.io.FileOutputStream.writeBytes(Native Method) 在 java.io.BufferedOutputStream.write(BufferedOutputStream) 可运行.java:105) - 在 java.io.PrintStream.write(PrintStream.java:430) 处锁定 <0x6f314ba4> (a java.io.BufferedOutputStream) - 在 org.apache 处锁定 <0xd5d3504> (a java.io.PrintStream) .log4j.ConsoleAppender$SystemOutStream.write(ConsoleAppender.java:173) 在 sun.nio.cs.StreamEncoder.writeBytes(StreamEncoder.java:202) 在 sun.nio.cs.StreamEncoder.implFlushBuffer(StreamEncoder.java:272) 在sun.nio.cs.StreamEncoder.implFlush(StreamEncoder.java:276) 在 sun.nio.cs.StreamEncoder.flush(StreamEncoder.java:122) - 在 java 锁定 <0x6243a076> (a java.io.OutputStreamWriter)。io.OutputStreamWriter.flush(OutputStreamWriter.java:212) at org.apache.log4j.helpers.QuietWriter.flush(QuietWriter.java:57) at org.apache.log4j.WriterAppender.subAppend(WriterAppender.java:315) at org org.apache.log4j.AppenderSkeleton.doAppend(AppenderSkeleton.java:230) 处的 .apache.log4j.WriterAppender.append(WriterAppender.java:159) - 锁定 <0x45dbd560>(org.apache.log4j.ConsoleAppender)在 org. 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) 在 java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:441) 在 java.util.concurrent.FutureTask$Sync.innerRun(FutureTask/java:268) 在 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) 在 java.lang。线程运行(线程.java:619)第907章)第907章)