Hi Neil, sorry for my delay. On 02/08/2018 18:37, NeilBrown wrote: > On Thu, Aug 02 2018, Guilherme G. Piccoli wrote: >> [...] >> Regarding the current behavior, one test I made was to remove 1 device >> of a 2-disk raid0 array and after that, write a file. Write completed >> normally (no errors from the userspace perspective), and I hashed the >> file using md5. I then rebooted the machine, raid0 was back with the 2 >> devices, and guess what? >> The written file was there, but corrupted (with a different hash). I >> don't think this is something fine, user could have written important >> data and don't realize it was getting corrupted while writing. > > > In your test, did you "fsync" the file after writing to it? That is > essential for data security. > If fsync succeeded even though the data wasn't written, that is > certainly a bug. If it doesn't succeed, then you know there is a > problem with your data. > Yes, I did. After writing, I ran both "sync" and "sync -f" after "dd" command complete (with no errors). The sync procedures also finished without errors, and the file was there. After a reboot, though, the file has a different md5, since it was corrupted. >> [...] >> Using the udev/mdadm to notice a member has failed and the array must be >> stopped might work, it was my first approach. The main issue here is >> timing: it takes "some time" until userspace is aware of the failure, so >> we have a window in which writes were sent between >> >> (A) the array member failed/got removed and >> (B) mdadm notices and instruct driver to refuse new writes; > > I don't think the delay is relevant. > If writes are happening, then the kernel will get write error from the > failed devices and can flag the array as faulty. > If writes aren't happening, then it no important cost in the "device is > removed" message going up to user-space and back. The problem with the time between userspace notice something is wrong and "warn" the kernel to stop writes is that many writes will be sent to the device in this mean time, and they can completed later - handling async completions of dead devices proved to be tricky, at least in my approach. Also, writeback threads will be filled with I/Os to be written to the dead devices too, this is other part of the problem. If you have suggestions to improve my approach, or perhaps a totally different idea than mine, I highly appreciate the feedback. Thank you very much for the attention. Cheers, Guilherme > > NeilBrown > >> >> between (A) and (B), those writes are seen as completed, since they are >> indeed complete (at least, they are fine from the page cache point of >> view). Then, writeback will try to write those, which will cause >> problems or they will complete in a corrupted form (the file will >> be present in the array's filesystem after array is restored, but >> corrupted). >> >> So, the in-kernel mechanism avoided most part of window (A)-(B), >> although it seems we still have some problems when nesting arrays, >> due to this same window, even with the in-kernel mechanism (given the >> fact it takes some time to remove the top array when a pretty "far" >> bottom-member is failed). >> >> More suggestions on how to deal with this in a definitive manner are >> highly appreciated. >> Thanks, >> >> >> Guilherme -- dm-devel mailing list dm-devel@xxxxxxxxxx https://www.redhat.com/mailman/listinfo/dm-devel