Are DB queries initiated from Java always blocking I/O?(从Java启动的数据库查询是否总是阻塞I/O?)
问题描述
假设一些阻塞I/O是在Java中完成的,例如长时间运行的数据库查询。在Java中,通常有没有一种方法可以让一些Java数据库驱动程序告诉JVM调度器,调用已经离开JVM,现在正在由某个外部系统处理?然后,JVM可以将服务数据库查询的线程分配给某个其他操作,直到来自数据库的回复到达为止。这样,阻塞数据库查询将有效地变为非阻塞。
我只是想知道是否可以在一般的JVM上这样做。我使用Java已经有很多年了,但我必须承认,我不知道Java调度程序在这种情况下会做什么。
推荐答案
假设一些阻塞I/O是在Java中完成的,例如长时间运行的数据库查询。在Java中,通常有没有一种方法可以让一些Java数据库驱动程序告诉JVM调度程序,调用已经离开JVM,现在正在由某个外部系统处理?
呃,不。线程的全部意义在于,如果它们阻塞,则可以调度一个不同的线程接管处理器或其他资源。您不希望JVM以某种方式使用相同的线程,该线程保存所有的JDBC状态、堆栈帧、变量等。您确实希望将相同的处理器和其他系统资源用于不同线程的任务。请记住,线程的开销相对较低。在现代系统上,当JVM中有数千个堆栈时,您可能会开始遇到问题,主要是因为它们每个都分配了一个固定的堆栈空间区域。
作为程序员,我们对此进行优化的方法是使用多线程、线程池、数据库连接池等。然后,当查询阻塞时,其他线程和查询可以并行工作,以最大化系统吞吐量。
这篇关于从Java启动的数据库查询是否总是阻塞I/O?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:从Java启动的数据库查询是否总是阻塞I/O?


基础教程推荐
- FirebaseListAdapter 不推送聊天应用程序的单个项目 - Firebase-Ui 3.1 2022-01-01
- Java:带有char数组的println给出乱码 2022-01-01
- 如何使用 Java 创建 X509 证书? 2022-01-01
- 降序排序:Java Map 2022-01-01
- 减少 JVM 暂停时间 >1 秒使用 UseConcMarkSweepGC 2022-01-01
- 无法使用修饰符“public final"访问 java.util.Ha 2022-01-01
- “未找到匹配项"使用 matcher 的 group 方法时 2022-01-01
- Java Keytool 导入证书后出错,"keytool error: java.io.FileNotFoundException &拒绝访问" 2022-01-01
- 在 Libgdx 中处理屏幕的正确方法 2022-01-01
- 设置 bean 时出现 Nullpointerexception 2022-01-01