Re: Consistent time attributes (ctime, atime and mtime) across replica set and distribution set

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On 02/28/2017 12:51 AM, Mohammed Rafi K C wrote:
Hi All,


We discussed the problem $subject in the mail thread [1]. Based on the
comments and suggestions I will summarize the design (Made as points for
simplicity.)

Some generic comment(s),

- I would like to see the design in such a form that, when server side replication and disperse become a reality, parts of the design/implementation remain the same. This way work need not be redone when server side anything happens. (I would have extended this to adapt to DHT2 as well, but will leave that to you)

- As this evolves we need to assign clear responsibilities to different xlators that we are discussing, which will eventually happen anyway, but just noting it ahead for clarity as we discuss this further.



1) As part of each fop, top layer will generate a time stamp and pass it
to the down along with other param.

    1.1) This will bring a dependency for NTP synced clients along with
servers

As stated by others and even noted by you, this requirement is a bit of a bother, but as the current DHT, AFR, EC architecture stands, this is what we need to start with. Just noting my observation as well on this.


    1.2) There can be a diff in time if the fop stuck in the xlator for
various reason, for ex: because of locks.


2) On the server posix layer stores the value in the memory (inode ctx)
and will sync the data periodically to the disk as an extended attr

I believe this should not be a part of the posix xlator. our posix store definition is that it uses a local file-system underneath that is POSIX compliant. This need, for storing the time information outside of POSIX specification (as an xattr or otherwise), is something that is gluster specific. As a result we should not fold this into the posix xlator.

For example, if we replace posix later with a db store, or a key-vlaue store, we would need to code this cache management of time information again for these stores, but if we abstract it out, then we do not need to do the same.

I may need to chew on this further, but at the moment I think this functionality should be stuffed into posix-xlator, and rather should live on its own.


     2.1) of course sync call also will force it. And fop comes for an
inode which is not linked, we do the sync immediately.


3) Each time when inodes are created or initialized it read the data
from disk and store it.


4) Before setting to inode_ctx we compare the timestamp stored and the
timestamp received, and only store if the stored value is lesser than
the current value.


5) So in best case data will be stored and retrieved from the memory. We
replace the values in iatt with the values in inode_ctx.


6) File ops that changes the parent directory attr time need to be
consistent across all the distributed directories across the subvolumes.
(for eg: a create call will change ctime and mtime of parent dir)

     6.1) This has to handle separately because we only send the fop to
the hashed subvolume.

     6.2) We can asynchronously send the timeupdate setattr fop to the
other subvoumes and change the values for parent directory if the file
fops is successful on hashed subvolume.

Am I right in understanding that this is not part of the solution, and just a suggestion on what we may do in the future, or is it part of the solution proposed?

If the latter (i.e part of the solution proposed), which layer has the responsibility to asynchronously update other DHT subvolumes?

For example, posix-xlator does not have that knowledge, so it should not be that xlator, which means it is some other xlator, now is that on the client or on the server, and how is it crash consistent are some things that come to mind when reading this, but will wait for the details before thinking aloud.


     6.3) This will have a window where the times are inconsistent
across dht subvolume (Please provide your suggestions)


7) Currently we have couple of mount options for time attributes like
noatime, relatime , nodiratime etc. But we are not explicitly handled
those options even if it is given as mount option when gluster mount. [2]

     7.1) We always relay on back end storage layer behavior, if you
have given those mount options when you mount your disk, you will get
this behaviour

     7.2) Now if we are taking effort to fix the consistency issue, do
we need to honour those options by our own ?


Please provide your comments and suggestions.


[1] :
http://lists.gluster.org/pipermail/gluster-devel/2016-January/048003.html


Regards

Rafi KC


_______________________________________________
Gluster-devel mailing list
Gluster-devel@xxxxxxxxxxx
http://lists.gluster.org/mailman/listinfo/gluster-devel

_______________________________________________
Gluster-devel mailing list
Gluster-devel@xxxxxxxxxxx
http://lists.gluster.org/mailman/listinfo/gluster-devel



[Index of Archives]     [Gluster Users]     [Ceph Users]     [Linux ARM Kernel]     [Linux ARM]     [Linux Omap]     [Fedora ARM]     [IETF Annouce]     [Security]     [Bugtraq]     [Linux]     [Linux OMAP]     [Linux MIPS]     [eCos]     [Asterisk Internet PBX]     [Linux API]

  Powered by Linux