- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
为什么 Linux 内核 AIO 不支持异步“打开”系统调用?因为 'open' 会在文件系统上阻塞很长时间,不是吗?
最佳答案
首先,这是一个非常好的合理问题; downvote 是不幸的,它可能把比我更有知识的人赶走了。
AFAICT,没有好的理由。您设法挖掘的讨论是相关的,但根本不令人满意(这可能也是您的结论)。尽管 Torvald 的观点在技术上是正确的,但他们显然忽视了房间里的大象——GUI 编程——以及我确信的许多其他用例。
是的,网络服务器会受到网络延迟的限制。这应该是不关心所有其他 IO 的理由,这有点可疑,但我可以接受。
是的,许多服务器工作负载将能够使用 dentry/inode 缓存,但不是全部,而且总会有遗漏。
是的,“购买更多 RAM”的说法有效。我从来没有发现这是一个很好的论点。
然后是所有其他用例。对于许多人来说,包括 GUI 编程,我们有时或经常阻塞并不重要;我们永远不应该阻止。如果访问模式非常随机且时间间隔很远,那么购买更多 RAM 也无济于事——除非拥有与辅助存储提供的容量一样大的容量。
“反正要快”的想法也是错误的;始终考虑远程文件系统。
唯一引人注目的一点是:
Short and sweet: "aio_open()" is basically never supposed to be an issue. If it is, you've misdesigned something, or you're trying too damn hard to single-thread everything (and "hiding" the threading that does happen by just calling it "AIO" instead - lying to yourself, in short).
这里的重点恰恰是为了避免线程,所以这句话让我很惊讶。甚至列举了其他论点这一事实在我看来表明,这个论点太脆弱了,无法独立存在。
在同一个讨论中深入挖掘,您可以找到 Mikulas Patocka 的这篇帖子:
You can emulate asynchronous IO with kernel threads like FreeBSD and some commercial Unices do, but you still need as many (possibly kernel) threads as many requests you are servicing.
(...)
Making real async IO would require to rewrite all filesystems and whole VFS _from_scratch_. It won't happen.
http://lkml.iu.edu//hypermail/linux/kernel/0102.1/0074.html
这听起来像是一个正确的解释,但显然不是一个好的解释。
请记住,这是一个旧线程,此后发生了很多变化,因此这个答案的值(value)很小。但是,它提供了关于为什么假设的 aio_open
历史上 不可用的见解。此外,要了解许多内核讨论(或与此相关的任何项目的任何内部讨论)通常期望所有参与者都从大量假设开始。因此,我完全有可能没有以正确的方式看待这个问题。
话虽如此,这一点很有趣(Stephen C. Tweedie):
Ahh, but even VMS SYS$QIO is synchronous at doing opens, allocation of the IO request packets, and mapping file location to disk blocks. Only the data IO is ever async (and Ben's async IO stuff for Linux provides that too).
http://lkml.iu.edu//hypermail/linux/kernel/0102.1/0139.html
为什么有趣?因为它强化了这样一种观念,即许多不同的系统不会异步实现 open
(和其他调用)。此外,aio_open
不是由 POSIX 指定的,我找不到解释原因的讨论。 Windows 似乎也忽略了这个问题。
就好像这个概念中有一些内在的东西是错误的或困难的,除了似乎没有人能很好地说明为什么最终会这样。
我的猜测是这只是低优先级,而且一直都是。包括线程化或预先打开文件在内的变通办法对于足够多的用例来说应该是足够的,这些用例可以提供功能,但永远不会被证明是合理的。
了解为什么 POSIX 没有定义这样的调用会很有趣。不过,我希望有一个“超出范围”的理由。
如果你想弄个水落石出,我想你必须把讨论带到更合适的 channel ,比如 LKML。
关于Linux内核AIO,开启系统调用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22780822/
我有这个代码: System.err.print("number of terms = "); System.out.println(allTerms.size()); System.err
我有以下问题:在操作系统是 Linux 的情况下和在操作系统是 MacOs 的情况下,我必须执行不同的操作。 所以我创建了以下 Ant 脚本目标: /u
我正在调用 system("bash ../tools/bashScript\"This is an argument!\"&"),然后我正在调用 close(socketFD) 直接在 system
使用最初生成的随机元素来约束随机数组的连续元素是否有效。 例如:我想生成一组 10 个 addr、size 对来模拟典型的内存分配例程并具有如下类: class abc; rand bit[5:0
我正在创建一个必须使用system(const char*)函数来完成一些“繁重工作”的应用程序,并且我需要能够为用户提供粗略的进度百分比。例如,如果操作系统正在为您移动文件,它会为您提供一个进度条,
我即将编写一些项目经理、开发人员和业务分析师会使用的标准/指南和模板。目标是更好地理解正在开发或已经开发的解决方案。 其中一部分是提供有关记录解决方案的标准/指南。例如。记录解决/满足业务案例/用户需
在开发使用压缩磁盘索引或磁盘文件的应用程序时,其中部分索引或文件被重复访问(为了论证,让我们说一些类似于 Zipfian 分布的东西),我想知道什么时候足够/更好地依赖操作系统级缓存(例如,Debia
我们编写了一个 powershell 脚本,用于处理来自内部系统的图像并将其发送到另一个系统。现在,业务的另一部分希望加入其中,对数据进行自己的处理,并将其推送到另一个系统。打听了一下,公司周围有几个
我正在尝试朗姆酒我的应用程序,但我收到以下错误:System.Web.HttpUnhandledException:引发了“System.Web.HttpUnhandledException”类型的异
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 要求我们推荐或查找工具、库或最喜欢的场外资源的问题对于 Stack Overflow 来说是偏离主题的,
所以我在其他程序中没有收到此错误,但我在这个程序中收到了它。 这个程序是一个我没有收到错误的示例。 #include int main() { system("pause"); } // en
我在 c# System.URI.FormatExption 中遇到问题 为了清楚起见,我使用的是 Segseuil 的 Matlab 方法,并且它返回一个图片路径 result。我想为其他用户保存此
我正在尝试像这样设置文本框的背景色: txtCompanyName.BackColor = Drawing.Color.WhiteSmoke; 它不喜欢它,因为它要我在前面添加系统,例如: txtCo
请帮助我解决 System.StackOverflowException我想用 .aspx 将记录写入数据库我使用 4 层架构来实现这一切都正常但是当我编译页面然后它显示要插入数据的字段时,当我将数据
我使用了一些通常由系统调用的API。 因此,我将 android:sharedUserId="android.uid.system" 添加到 manifest.xml, 并使用来自 GIT 的 And
我正在尝试创建一个小型应用程序,它需要对/system 文件夹进行读/写访问(它正在尝试删除一个文件,并创建一个新文件来代替它)。我可以使用 adb 毫无问题地重新挂载该文件夹,如果我这样做,我的应用
我想从没有 su 的系统 priv-app 将/system 重新挂载为 RW。如何以编程方式执行此操作?只会用 Runtime.getruntime().exec() 执行一个 shell 命令吗
我正在尝试制作一个带有登录系统的程序我对此很陌生,但我已经连续工作 8 个小时试图解决这个问题。这是我得到的错误代码 + ServerVersion 'con.ServerVersion' threw
当我“构建并运行”Code::Blocks 中的程序时,它运行得非常好!但是当我从“/bin”文件夹手动运行它时,当它试图用 system() 调用“temp.bat”时,它会重置。这是为什么?它没有
我想使用 system/pipe 命令来执行具有特殊字符的命令。下面是示例代码。通过系统/管道执行命令后,它通过改变特殊字符来改变命令。我很惊讶地看到系统命令正在更改作为命令传递的文本。 run(ch
我是一名优秀的程序员,十分优秀!