草庐IT

阻塞IO

全部标签

java - Tomcat 6.0.28 在浸泡测试期间由于线程阻塞而无响应

我们对在Tomcat6.0.28和OpenJDK运行时环境(IcedTea61.11.11)上运行的新版JavaEEWeb应用程序进行了多次浸泡测试。问题出现在web层。一段时间后-第一次50分钟,第二次1小时,第三次2.5小时-我们集群Web层中的一个随机Tomcat停止响应。查看线程转储,我们看到大量线程突然阻塞。当问题发生时,线程数从93增加到437。437个线程中的341个在WebappClassLoader上被阻塞,如下所示:"TP-Processor400"daemonprio=10tid=0x00007f1ee432e800nid=0x44d9waitingformoni

java - 修复了线程池线程阻塞,当提交了足够多的任务时

我有一个流程需要并行计算许多小任务,然后按任务的自然顺序处理结果。为此,我进行了以下设置:一个简单的ExecutorService和一个阻塞队列,当Callable提交给执行程序时,我将使用它来保持返回的Future对象:ExecutorServiceexec=Executors.newFixedThreadPool(15);LinkedBlockingQueue>futures=newLinkedBlockingQueue>(15*64);一些调试代码,用于计算提交的数量和已处理的任务数量,并定期将它们写出来(注意processed在任务代码本身的末尾递增):AtomicLongpr

Java Serializable、ObjectInputstream、非阻塞 I/O

我刚刚开始使用Java序列化,我不清楚在非阻塞I/O的情况下您应该如何从源获取对象。我能找到的所有文档都建议使用ObjectInputStream是读取序列化对象的正确方法。但是,正如我提到的,我正在使用java.nio并执行非阻塞操作。如果readObject()将阻塞直到有新对象可用,这对我没有帮助总结..使用JavaNIO时如何进行序列化? 最佳答案 将序列化实例包装在一个报告有效负载长度的协议(protocol)中,有效负载就是所讨论的实例。然后,一旦您知道您有一个表示完整实例的段,您就可以安全地使用ObjectInputS

java.io.IOException - IO 流读取结束

代码似乎在session.connect中断。com.jcraft.jsch.JSchException:Session.connect:java.io.IOException:EndofIOStreamRead堆栈跟踪com.jcraft.jsch.JSchException:Session.connect:java.io.IOException:EndofIOStreamReadatcom.jcraft.jsch.Session.connect(Session.java:534)atcom.jcraft.jsch.Session.connect(Session.java:162)a

将大量 JAR 添加到类路径时,Java 文件 IO 性能下降超过 30%

测试代码:importjava.io.BufferedReader;importjava.io.FileReader;importjava.io.IOException;importjava.util.Map.Entry;publicclassReadLine{/***@paramargs*@throwsIOException*/publicstaticvoidmain(String[]args)throwsIOException{System.getenv();System.getProperties();BufferedReaderbr=newBufferedReader(newF

java - SelectorImpl 被阻塞

我用了很多客户端向服务器发送请求,一个客户端每秒大约1000个请求,服务器的CPU很快就升到600%(8核),并一直保持这种状态。当我使用jstack打印流程内容时,发现SelectorImpl是BLOCKED状态。记录如下:nioEventLoopGroup-4-1prio=10tid=0x00007fef28001800nid=0x1dbfwaitingformonitorentry[0x00007fef9eec7000]java.lang.Thread.State:BLOCKED(onobjectmonitor)atsun.nio.ch.EPollSelectorImpl.doS

java - 在图和子图上表示和执行 IO

我有一个问题,我需要对循环图执行CRUD操作。现在我知道那里有很多图形数据库,但我有一组特定的用例,这些用例在这些数据库中不受支持(或者至少我不知道它们)。以下是我的构造:节点:可以有多个源和目标有向边:连接两个节点节点组:多个节点(有边相连)组成一个组(简单来说就是一个更小的图)有向图:由多个节点、节点组和边组成。该图可以是循环的。以下是我可以拥有的功能:我可以通过定义传入和传出边定义来简单地创建一个节点。我可以通过添加节点并用边连接它们来创建一个简单的图。我可以执行标准的图形遍历。我现在可以对图的节点进行分组并将其称为节点组,我可以在其中使用此节点组的多个实例(就像节点一样)另一个

java - System.out.println 最终阻塞

我有一个应用程序将其所有日志记录合并到一个单实例类中,以便于选择性调试打印等。该类已经存在了一年左右,运行顺利,但就在最近我碰巧打开了日志升级到最高设置(我很少这样做),标准输出似乎最终会阻塞。这会在下次代码的其他部分调用println时,或者当它尝试使用日志记录类(它被阻止等待println返回)时造成严重破坏。我的第一个想法是我的日志记录类存在某种并发问题,但是搜索堆栈跟踪让我确信我的同步工作正常并且在任何给定时间只有一个线程尝试写入控制台.这是有问题的线程上的示例堆栈跟踪:Thread[Thread-127](Suspended)FileOutputStream.writeByt

java.sql.SQLException : Io exception: Socket read timed out vs Closed Connection 异常

我正在尝试研究有关连接到Oracle数据库的以下两个错误的问题:关闭连接java.sql.SQLException:Io异常:Socket读取超时我的理解:关闭连接:发生是因为存在某种网络中断或数据库由于某种“不活动”而关闭了sessionjava.sql.SQLException:Ioexception:Socketreadtimedout:这是连接成功建立但由于某种原因套接字/数据为空并最终超时的情况因为没有可用数据。是否可以在本地OracleDB环境中复制上述错误?步骤是什么?非常感谢您花时间回复。谢谢。 最佳答案 你对关闭连

java.sql.SQLException : Io exception: Broken pipe how to recover without restart? 异常

在我的应用程序中,我使用到Oracle的连接,当连接丢失并尝试重新连接时,我收到异常:java.sql.SQLException:Ioexception:Brokenpipeatoracle.jdbc.driver.DatabaseError.throwSqlException(DatabaseError.java:124)atoracle.jdbc.driver.DatabaseError.throwSqlException(DatabaseError.java:161)atoracle.jdbc.driver.DatabaseError.throwSqlException(Data