diff options
| author | Raghavendra Bhat <raghavendra@redhat.com> | 2015-04-09 15:38:47 +0530 | 
|---|---|---|
| committer | Niels de Vos <ndevos@redhat.com> | 2015-05-10 08:14:33 -0700 | 
| commit | da48a6a596251c19a8ddb1bdfec3da9744a78b8f (patch) | |
| tree | c2835e85440ca2c17f55641d2312a9dd345dad6a /libglusterfs/src | |
| parent | d1d54d027fc616ccae5c329d5b5f02ee9aab1549 (diff) | |
features/bit-rot-stub: versioning of objects in write/truncate fop instead of open
* This patch brings in the changes where object versioning is done in write and
  truncate fops instead of tracking them in open and create fops. This model
  works for both regular and anonymous fds. It also removes the race associated
  with open calls, create and lookups.
  This patch follows the below method for object versioning and notifications:
  Before sending writev on the fd, increase the ongoing
  version first. This makes anonymous fd write similar to the regular
  fd write by having the ongoing version increased before doing the
  write.
  Do following steps to do versioning:
  1) For anonymous fds set the fd context (so that release is invoked) and add
     the fd context to the list maintained in the inode context.
     For regular fds the above think would have been done in open itself.
  2) Increase the on-disk ongoing version
  3) Increase the in memory ongoing version and mark inode as non-dirty
  3) Once versioning is successfully done send write operation. If
     versioning fails, then fail the write fop.
  5) In writev_cbk mark inode as modified.
> Change-Id: I7104391bbe076d8fc49b68745d2ec29a6e92476c
> BUG: 1207979
> Signed-off-by: Raghavendra Bhat <raghavendra@redhat.com>
> Reviewed-on: http://review.gluster.org/10233
> Tested-by: Gluster Build System <jenkins@build.gluster.com>
> Reviewed-by: Vijay Bellur <vbellur@redhat.com>
Change-Id: I4bb86989b5fab02b9ed2950798b1a80e566f1024
BUG: 1220041
Signed-off-by: Raghavendra Bhat <raghavendra@redhat.com>
Reviewed-on: http://review.gluster.org/10722
Reviewed-by: Gaurav Kumar Garg <ggarg@redhat.com>
Tested-by: NetBSD Build System
Tested-by: Gluster Build System <jenkins@build.gluster.com>
Diffstat (limited to 'libglusterfs/src')
| -rw-r--r-- | libglusterfs/src/changelog.h | 2 | 
1 files changed, 1 insertions, 1 deletions
diff --git a/libglusterfs/src/changelog.h b/libglusterfs/src/changelog.h index 08307810704..6f86e5a54cd 100644 --- a/libglusterfs/src/changelog.h +++ b/libglusterfs/src/changelog.h @@ -42,9 +42,9 @@ struct ev_release {  };  struct ev_release_br { -        int32_t flags;          unsigned long version;          unsigned char gfid[16]; +        int32_t sign_info;  };  struct ev_changelog {  | 
