我在 Linux 2.6.16.46 上玩这段代码:
io.aio_fildes = open(name, O_CREAT | O_TRUNC | O_WRONLY | O_SYNC, 00300);
io.aio_buf = buffer;
io.aio_nbytes = size;
io.aio_sigevent = sigev;
io.aio_lio_opcode = LIO_WRITE;
aio_write( &io );
这里应该使用buffer指向的内存进行IO操作。尽管如此,我还是看到脏页的数量在上升,就好像我正在写入缓存一样。这是为什么?
在构建机器上,open() 中没有 O_DIRECT 支持。但是因为我没有使用 write(),那仍然是个问题吗?
我很确定目标有直接的 IO 支持。
最佳答案
想通了。直接/缓冲 IO 是一回事,同步/异步是另一回事。要让异步写入避免缓存,即使未使用 write(),仍然需要将 O_DIRECT 提供给 open() 调用。
一开始可能会出现编译错误 - 请仔细阅读 man 2 open。
关于linux - 使用 aio_write() 但仍然看到数据通过缓存?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3532952/