diff options
| author | Saravanakumar Arumugam <sarumuga@redhat.com> | 2015-10-14 11:49:49 +0530 | 
|---|---|---|
| committer | Venky Shankar <vshankar@redhat.com> | 2015-10-26 05:00:14 -0700 | 
| commit | 6188b5fcebc56b3d8af1956beeec9988f3e8f268 (patch) | |
| tree | 156e2111c94a75fb8ba7ec211f55047d8031e712 /geo-replication/syncdaemon/monitor.py | |
| parent | 4f65f894ab1c19618383ba212dc0f0df48675823 (diff) | |
geo-rep: Avoid cold tier bricks during ENTRY operation
This is a series of patch which aims to fix geo-replication
in a Tiering Volume.
Problem:
Consider, a file is placed in volume initially and then hot tier is
attached. During any operation on the file, due to lookup a linkto
file is created in hot tier.
Now, any namespace operation carried out on the file is recorded in
both cold and hot tier.
There is a room for races when both changelogs are replayed.
Solution:
So, We are going to replay (namespace related)operations
only in the hot tier.
Why?
a. If the file is directly placed in Hot tier , all fops will be
recorded in HOT tier.
b. If  the file is already present in Cold tier, and if any fop is
carried out, it creates linkto file in Hot tier.
Now, operations like UNLINK, RENAME are captured in Hot
tier(by means of linkto file).
This way, we can get both tier's operation in HOT tier itself.
Now, once the file is demoted to COLD tier, any namespace operation
carried out on the cold tier can be avoided as we directly RECORD
the same in HOT tier.
How?
1. Check whether the brick is cold tier and skip ENTRY operation.
2. Also, if it is cold tier brick, use Xsync(which is used during initial run).
   This will help in getting all cold tier bricks changes using File System crawl
   and helps in avoiding races with hot tier brick(which can happen
   if historychangelog used in cold tier brick).
Dependent patches:
1. http://review.gluster.org/12239
2. http://review.gluster.org/12326
Change-Id: I7692b1dbb8813a7e253451bca02f8f09a5782dde
BUG: 1266875
Signed-off-by: Saravanakumar Arumugam <sarumuga@redhat.com>
Reviewed-on: http://review.gluster.org/12355
Tested-by: NetBSD Build System <jenkins@build.gluster.org>
Tested-by: Gluster Build System <jenkins@build.gluster.com>
Reviewed-by: Aravinda VK <avishwan@redhat.com>
Diffstat (limited to 'geo-replication/syncdaemon/monitor.py')
| -rw-r--r-- | geo-replication/syncdaemon/monitor.py | 17 | 
1 files changed, 13 insertions, 4 deletions
| diff --git a/geo-replication/syncdaemon/monitor.py b/geo-replication/syncdaemon/monitor.py index ba5c8e32514..c41eb969143 100644 --- a/geo-replication/syncdaemon/monitor.py +++ b/geo-replication/syncdaemon/monitor.py @@ -99,6 +99,10 @@ class Volinfo(object):      def get(self, elem):          return self.tree.findall('.//' + elem) +    def is_cold(self, brickpath): +        logging.debug('brickpath: ' + repr(brickpath)) +        return brickpath in self.cold_bricks +      @property      @memoize      def bricks(self): @@ -127,6 +131,10 @@ class Volinfo(object):      def disperse_count(self):          return int(self.get('disperseCount')[0].text) +    @property +    @memoize +    def cold_bricks(self): +        return [b.text for b in self.get('coldBricks/brick')]  class Monitor(object): @@ -248,9 +256,9 @@ class Monitor(object):                                                   '--rpc-fd',                                                   ','.join([str(rw), str(ww),                                                             str(ra), str(wa)]), -                                                 '--subvol-num', str(w[2]), -                                                 '--resource-remote', -                                                 remote_host]) +                                                 '--subvol-num', str(w[2])] + +                         (['--is-coldtier'] if w[3] else []) + +                         ['--resource-remote', remote_host])              cpids.add(cpid)              agents.add(apid) @@ -377,7 +385,8 @@ def distribute(*resources):                  slaves = slavevols      workerspex = [(brick['dir'], slaves[idx % len(slaves)], -                  get_subvol_num(idx, mvol.replica_count, mvol.disperse_count)) +                  get_subvol_num(idx, mvol.replica_count, mvol.disperse_count), +                  mvol.is_cold(":".join([brick['host'], brick['dir']])))                    for idx, brick in enumerate(mvol.bricks)                    if is_host_local(brick['host'])]      logging.info('worker specs: ' + repr(workerspex)) | 
