Will data written via write() be flushed to disk if a process is killed?

拥有回忆 提交于 2019-12-02 14:38:16

问题


I'm working with a program that uses qdbm to maintain a key-value store (qdbm is linked into the program). In certain cases, the process puts a value in the qdbm database and then restarts itself by calling an external init script (via system()). It appears that sometimes a value written to the qdbm database doesn't actually stick, and I'm wondering if it could be due to the data not getting flushed to disk before the process is killed via SIGTERM.

Since qdbm does writes using the write() system call (versus say, the fwrite() library function), I would think that the Linux kernel should know to flush everything to disk eventually (the system doesn't get restarted, just the process). Also, close() does get called on the FD before the process is killed.

So, is my understanding correct, or do I need to add some fdatasync() or similar calls in there somewhere? Links to authoritative references on the semantics here would also be appreciated.


回答1:


Normally, the data already written by the application into a kernel buffer with write() will not be affected by the application exiting or getting killed in any way. Exiting or getting killed implicitly closes all file descriptors, so there should be no difference, the kernel will handle the flushing afterwards. So no fdatasync() or similar calls are neccessary.

There are two exceptions to this:

  • if the application uses user-land buffering (not calling the write() system call, but instead caching the data in a user-space buffer, with fwrite()), those buffers might not get flushed unless a proper user-space file close is executed - getting killed by a SIGKILL will definitely cause you to lose the contents of those buffers,

  • if the kernel dies as well (loss of power, kernel crash, etc.), your data might have missed getting written to the disks from the kernel buffers, and will then get lost.



来源:https://stackoverflow.com/questions/19647997/will-data-written-via-write-be-flushed-to-disk-if-a-process-is-killed

标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!