- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
我正在寻找有关如何为我在 Ubuntu Linux 14.04 上运行的应用程序获得高效和高性能异步 IO 的建议。
我的应用程序处理事务并在磁盘/闪存上创建一个文件。随着应用程序通过事务进行,额外的块被创建,这些块必须附加到磁盘/闪存上的文件中。该应用程序还需要在处理新事务时频繁读取该文件的块。每个事务可能需要从这个文件中读取一个不同的块,此外还要创建一个必须附加到这个文件的新块。有一个传入的事务队列,应用程序可以继续处理队列中的事务,以创建足够深的 IO 操作管道,以隐藏磁盘或闪存上的读取访问或写入完成的延迟。对于尚未写入磁盘/闪存的块(由前一个事务放入写入队列)的读取,应用程序将停止,直到相应的写入完成。
我有一个重要的性能目标——应用程序应该产生尽可能低的延迟来发出 IO 操作。我的应用程序需要大约 10 微秒来处理每个事务,并准备好向磁盘/闪存上的文件发出写入或读取。发出异步读取或写入的额外延迟应尽可能小,以便应用程序可以在仅需要写入文件时以每个事务接近 10 微秒的速率完成每个事务的处理。
我们正在试验一种使用 io_submit 发出写入和读取请求的实现。对于满足我们要求的最佳方法的任何建议或反馈,我将不胜感激。 io_submit 是否会给我们提供最佳性能来实现我们的目标?对于每次写入 io_submit 的延迟和每次读取 io_submit 的延迟,我应该期待什么?
使用我们的实验代码(在 2.3 GHz Haswell Macbook Pro、Ubuntu Linux 14.04 上运行),我们在扩展输出文件时测量了大约 50 微秒的写入 io_submit。这太长了,我们甚至还没有接近我们的性能要求。任何帮助我以最少的延迟启动写入请求的指导将不胜感激。
最佳答案
Linux AIO(有时称为 KAIO 或 libaio
)是一种黑魔法,经验丰富的从业者知道其中的陷阱,但出于某种原因,它是 taboo to tell someone about gotchas they don't already know .通过在网上摸索和经验,我想出了几个例子,其中 Linux 的 通过 io_submit()
提交异步 I/O 可能变得(静默)同步,从而将其变成阻塞(即不再快速)调用:
O_DIRECT
“提示”(例如,您提交 I/O 的方式不符合 O_DIRECT
对齐约束,文件系统或特定文件系统的配置不支持 O_DIRECT
)并且它选择 silently perform buffered I/O instead ,导致上述情况。 io_submit()
当另一个操作完成时,再次将变成阻塞调用。 Seastar framework contains a small lookup table of filesystem specific cases . /sys/block/[disk]/queue/nr_requests
documentation 和未记录的 /sys/block/[disk]/device/queue_depth
) 在内核中。制作 I/O requests back-up and exceed the size of the kernel queues leads to blocking ./sys/block/[disk]/queue/max_sectors_kb
但大于 true limit may be something smaller like 512 KiB),它们将在块层内拆分并继续处理多个请求。 /proc/sys/fs/aio-max-nr
documentation)也会产生影响,但结果将在 io_setup()
中看到。而不是 io_submit()
. i_rwsem
)。 RWF_NONBLOCK
flag可以用来制作上面嘈杂的一些阻塞场景。例如,当使用缓冲并尝试读取尚未在页面缓存中的数据时,
RWF_NONBLOCK
flag will cause submission to fail with EAGAIN
when blocking would otherwise occur .显然,您仍然 a) 需要支持此标志的 4.14(或更高版本)内核,并且 b) 必须了解它未涵盖的情况。我注意到有
patches that have been accepted or are being proposed to return EAGAIN
in more scenarios that would otherwise block但在撰写本文时 (2019)
RWF_NONBLOCK
is not supported for buffered filesystem writes .
io_uring
这在不阻止提交方面做得更好(这是一个完全不同的界面,并且是 2020 年的新界面)。
io_submit()
阻塞/缓慢的情况。 ENOSPC
由于缺乏大量连续的可用空间。 O_DIRECT
rather than failing the open()
call .O_DIRECT
is requested on compressed files . O_DIRECT
to "accepting" it by falling back to buffered I/O (请参阅提交消息中的第 3 点)。在 ZFS on Linux "Direct IO" GitHub issue 中还有从引导到提交的进一步讨论。 .在“NVMe Read Performance Issues with ZFS (submit_bio to io_schedule)”问题中,有人建议他们是 getting closer to submitting a change that enables a proper zerocopy O_DIRECT
.如果接受这样的更改,它最终会出现在 ZoL 的某个 future 版本中大于 0.8.2。 O_DIRECT
allocating writes . io_submit()
的原因延误。还有一个 LWN article talking about an earlier version of the no-wait AIO patch set以及它没有涵盖的一些情况(但请注意,缓冲读取 最后被它涵盖了 )。 关于linux - Ubuntu Linux 中的异步 IO io_submit 延迟,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34572559/
IO 设备如何知道属于它的内存中的值在memory mapped IO 中发生了变化? ? 例如,假设内存地址 0 专用于保存 VGA 设备的背景颜色。当我们更改 memory[0] 中的值时,VGA
我目前正在开发一个使用Facebook sdk登录(通过FBLoginView)的iOS应用。 一切正常,除了那些拥有较旧版本的facebook的人。 当他们按下“使用Facebook登录”按钮时,他
假设我有: this - is an - example - with some - dashesNSRange将使用`rangeOfString:@“-”拾取“-”的第一个实例,但是如果我只想要最后
Card.io SDK提供以下详细信息: 卡号,有效期,月份,年份,CVV和邮政编码。 如何从此SDK获取国家名称。 - (void)userDidProvideCreditCardInfo:(Car
iOS 应用程序如何从网络服务下载图片并在安装过程中将它们安装到用户的 iOS 设备上?可能吗? 最佳答案 您无法控制应用在用户设备上的安装,因此无法在安装过程中下载其他数据。 只需在安装后首次启动应
我曾经开发过一款企业版 iOS 产品,我们公司曾将其出售给大型企业,供他们的员工使用。 该应用程序通过 AppStore 提供,企业用户获得了公司特定的配置文件(包含应用程序配置文件)以启用他们有权使
我正在尝试将 Card.io SDK 集成到我的 iOS 应用程序中。我想为 CardIO ui 做一个简单的本地化,如更改取消按钮标题或“在此保留信用卡”提示文本。 我在 github 上找到了这个
我正在使用 CardIOView 和 CardIOViewDelegate 类,没有可以设置为 YES 的 BOOL 来扫描 collectCardholderName。我可以看到它在 CardIOP
我有一个集成了通话工具包的 voip 应用程序。每次我从我的 voip 应用程序调用时,都会在 native 电话应用程序中创建一个新的最近通话记录。我在 voip 应用程序中也有自定义联系人(电话应
iOS 应用程序如何知道应用程序打开时屏幕上是否已经有键盘?应用程序运行后,它可以接收键盘显示/隐藏通知。但是,如果应用程序在分屏模式下作为辅助应用程序打开,而主应用程序已经显示键盘,则辅助应用程序不
我在模拟器中收到以下错误: ImageIO: CGImageReadSessionGetCachedImageBlockData *** CGImageReadSessionGetCachedIm
如 Apple 文档所示,可以通过 EAAccessory Framework 与经过认证的配件(由 Apple 认证)进行通信。但是我有点困惑,因为一些帖子告诉我它也可以通过 CoreBluetoo
尽管现在的调试器已经很不错了,但有时找出应用程序中正在发生的事情的最好方法仍然是古老的 NSLog。当您连接到计算机时,这样做很容易; Xcode 会帮助弹出日志查看器面板,然后就可以了。当您不在办公
在我的 iOS 应用程序中,我定义了一些兴趣点。其中一些有一个 Kontakt.io 信标的名称,它绑定(bind)到一个特定的 PoI(我的意思是通常贴在信标标签上的名称)。现在我想在附近发现信标,
我正在为警报提示创建一个 trigger.io 插件。尝试从警报提示返回数据。这是我的代码: // Prompt + (void)show_prompt:(ForgeTask*)task{
您好,我是 Apple iOS 的新手。我阅读并搜索了很多关于推送通知的文章,但我没有发现任何关于 APNS 从 io4 到 ios 6 的新更新的信息。任何人都可以向我提供 APNS 如何在 ios
UITabBar 的高度似乎在 iOS 7 和 8/9/10/11 之间发生了变化。我发布这个问题是为了让其他人轻松找到答案。 那么:在 iPhone 和 iPad 上的 iOS 8/9/10/11
我想我可以针对不同的 iOS 版本使用不同的 Storyboard。 由于 UI 的差异,我将创建下一个 Storyboard: Main_iPhone.storyboard Main_iPad.st
我正在写一些东西,我将使用设备的 iTunes 库中的一部分音轨来覆盖 2 个视频的组合,例如: AVMutableComposition* mixComposition = [[AVMutableC
我创建了一个简单的 iOS 程序,可以顺利编译并在 iPad 模拟器上运行良好。当我告诉 XCode 4 使用我连接的 iPad 设备时,无法编译相同的程序。问题似乎是当我尝试使用附加的 iPad 时
我是一名优秀的程序员,十分优秀!