Re: [PATCH v2 05/19] afs: convert to new i_version API
From: Jeffrey Altman
Date: Sat Dec 16 2017 - 11:33:53 EST
A few thoughts on AFS usage below which might impact a future revision
of the API. I hope they are useful.
On 12/16/2017 8:49 AM, Jeff Layton wrote:
> On Sat, 2017-12-16 at 08:46 -0500, Jeff Layton wrote:
>> From: Jeff Layton <jlayton@xxxxxxxxxx>
>> For AFS, it's generally treated as an opaque value, so we use the
>> *_raw variants of the API here.
>> Note that AFS has quite a different definition for this counter. AFS
>> only increments it on changes to the data, not for the metadata. We'll
>> need to reconcile that somehow if we ever want to present this to
>> userspace via statx.
From the patch series notes:
"The inode->i_version field is supposed to be a value that changes
whenever there is any data or metadata change to the inode. Some
filesystems use it internally to detect directory changes during
readdir. knfsd will use it if the filesystem has MS_I_VERSION set. IMA
will also use it to optimize away some remeasurement if it's available.
NFS and AFS just use it to store an opaque change attribute from the
"Only btrfs, ext4, and xfs increment it for data changes. Because of
this, these filesystems must log the inode to disk whenever the
i_version counter changes. That has a non-zero performance impact,
especially on write-heavy workloads, because we end up dirtying the
inode metadata on every write, not just when the times change. "
The AFS/AuriStorFS data version is an unsigned 64-bit value that is
incremented by the file server as part of a data changing operation. For
files, a StoreData and for directories entry manipulations such as
create, rename, delete. This data version is used to tag the version of
any subset of the data stream for caching and replication purposes.
As Jeff notes, the AFS data version is not incremented for metadata
changes. Metadata cannot be trusted by clients without acquiring a
callback promise from a fileserver. The callback promise will either be
satisfied by the issuing fileserver sending a CallBack notification that
the metadata is no longer valid OR the callback promise will expire.
Something else that is important to note that it is assumed that local
data changes that occur under a valid callback promise is newer than the
data on the fileserver. It might be useful if the new i_version API
supported major and minor version numbers. AFS implementations would
store the fileserver provided data version number as the major version
and would increment the minor version when local changes have been made
which have yet to be stored back to the fileserver. This functionality
would be especially useful if disconnected operations were implemented
for the AFS implementation.
It might also be useful to separate metadata version and data version
although some filesystems would set the same value to both. For AFS,
the metadata major version would the timestamp at which the callback was
adr:Suite 6B;;255 West 94Th Street;New York;New York;10025-6985;United States
title:Founder and CEO
Description: S/MIME Cryptographic Signature