> On Thu, 2 Aug 2001, Christoph Hellwig wrote:
>
> > > Well, if there's not a single dirent, you cannot retrieve the data,
> >
> > Of course you can, you can pass and fd for an unliked file
> > everywhere using AF_LOCAL descriptor passing.
>
> But this assumes the system doesn't crash, while
> fsync() seems meant more as a protection against
> the system going down unexpectedly ...
There is something to that. However taking this argument to
it's logical extreme I have you have to not only sync every directory
in the current path of the file. You have to sync your online file
index, because search engines is how we find things right?
Since the filename in unix is not part of the files metadata it is a
perfectly sane semantic for fsck to drop the file into /lost+found, if
no one cared enough about the index/directory to update it.
In the general case if you have the guarantee that a filesystem does
safe directory updates. So unless someone does an unlink you won't
loose your old link. For most cases it doesn't matter as your
directory entry for the file is much older than the file itself, and
has been already synched. MTA's are the exception to this where there
good filename is written only after the file is written.
The only other argument that seems to come from the MTA case is that
syscalls are slow, and a pain and programmers don't want to make two
or three syscalls just to do this. Heck if you are doing a sync you
are waiting for a disk which is slow. So speed doesn't really count.
There is probably an argument in there somewhere about batching up
I/O, so you have to wait a minimum amount of time for your sync. But
until someone benchmarks, and tries a few different approatches I
won't believe that you need a kernel change even for that.
My question is what does fsync do on directories in other unix's. It
would be really strange if it didn't behave similiarly to linux.
If forget wether it was AIX or HP-UX where doing a grep foo * would
also grep through "." . So at least open works on other peoples directores.
Eric
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/