summaryrefslogtreecommitdiffstats
path: root/libglusterfs/src/iatt.h
diff options
context:
space:
mode:
authorAnand Avati <avati@gluster.com>2010-09-03 13:58:11 +0000
committerVijay Bellur <vijay@dev.gluster.com>2010-09-04 01:45:01 -0700
commit2822157056d8347518f7e1b8bf9ee04bea7286ae (patch)
treee6d8b6e7f4b3435e190c7303a0b751390f5c8850 /libglusterfs/src/iatt.h
parentf5661d03f0f59cc2473f60232872ddafd325cd9d (diff)
gfid: introduce uuid based handles for inodes
gfid represents a gluter file id. This is a universally unique id assigned to a logical inode, independent of the inode numbers assigned by the various backend filesystems to that file/directory. The gfid of a file/directory will be the same on servers depending on the cluster translator in picture. The same gfid can be used as a handle across layers of various translators and across servers and clients. This was not the case previously as the cluster translators would pick the backend inode number from one of the servers and convert that into a logical inode number by performing some mathematical transforms. This new technique of addressing inodes also makes dynamic volume management have a more robust implementation as the file handles remain the same on all versions of the graphs, and allows for seamless NFS daemon restarts as well. This change makes way for server originating communication which was not possible earlier as the servers did not have any reliable way of addressing client side inodes at all. gfid solves this problem by preserving the same uuid as the handle on all the servers and across all clients Signed-off-by: Anand V. Avati <avati@blackhole.gluster.com> Signed-off-by: Anand V. Avati <avati@amp.gluster.com> Signed-off-by: Vijay Bellur <vijay@dev.gluster.com> BUG: 971 (dynamic volume management) URL: http://bugs.gluster.com/cgi-bin/bugzilla3/show_bug.cgi?id=971
Diffstat (limited to 'libglusterfs/src/iatt.h')
-rw-r--r--libglusterfs/src/iatt.h2
1 files changed, 2 insertions, 0 deletions
diff --git a/libglusterfs/src/iatt.h b/libglusterfs/src/iatt.h
index ef64f9afc..e67d714c2 100644
--- a/libglusterfs/src/iatt.h
+++ b/libglusterfs/src/iatt.h
@@ -31,6 +31,7 @@
#include <unistd.h>
#include "compat.h"
+#include "uuid.h"
typedef enum {
IA_INVAL = 0,
@@ -59,6 +60,7 @@ typedef struct {
struct iatt {
uint64_t ia_ino; /* inode number */
uint64_t ia_gen; /* generation number */
+ uuid_t ia_gfid;
uint64_t ia_dev; /* backing device ID */
ia_type_t ia_type; /* type of file */
ia_prot_t ia_prot; /* protection */