diff options
| author | shishir gowda <sgowda@redhat.com> | 2013-02-27 17:04:47 +0530 | 
|---|---|---|
| committer | Vijay Bellur <vbellur@redhat.com> | 2013-03-04 02:42:10 -0800 | 
| commit | 3335a3ded7f46ddcdf2a42edf0c6e78abeb9e898 (patch) | |
| tree | 91dbba0df65c20e3d9d033b38c7f3ca30f91e726 /xlators/cluster | |
| parent | f6a9f19be0e1afe7850842997b88182133d3464e (diff) | |
cluster/distribute: Prevent spurious multiple defrag crawls
In dht_notify, we used to create a thread to start defrag
crawls after we had heard from all child subvols.
This was in-correct, as a later event, could also trigger the
crawl again(due to the fact that all subvols had responded).
The fix is to make sure, the thread is started only once after
all subvols have responded the first time
BUG: 916449
Change-Id: I1619344fbb1cb51d5e1db38d8a29821fa870fa8b
Signed-off-by: shishir gowda <sgowda@redhat.com>
Reviewed-on: http://review.gluster.org/4610
Tested-by: Gluster Build System <jenkins@build.gluster.com>
Reviewed-by: Jeff Darcy <jdarcy@redhat.com>
Diffstat (limited to 'xlators/cluster')
| -rw-r--r-- | xlators/cluster/dht/src/dht-common.c | 23 | 
1 files changed, 14 insertions, 9 deletions
| diff --git a/xlators/cluster/dht/src/dht-common.c b/xlators/cluster/dht/src/dht-common.c index 945797820..aed81b83e 100644 --- a/xlators/cluster/dht/src/dht-common.c +++ b/xlators/cluster/dht/src/dht-common.c @@ -5086,15 +5086,7 @@ unlock:             or wait for anything else. Just propagate blindly */          if (have_heard_from_all) {                  propagate = 1; -                if (conf->defrag) { -                        ret = pthread_create (&conf->defrag->th, NULL, -                                              gf_defrag_start, this); -                        if (ret) { -                                conf->defrag = NULL; -                                GF_FREE (conf->defrag); -                                kill (getpid(), SIGTERM); -                        } -                } +          } @@ -5116,6 +5108,19 @@ unlock:                                  /* continue to check other events for CHILD_UP */                          }                  } + +                /* rebalance is started with assert_no_child_down. So we do +                 * not need to handle CHILD_DOWN event here. +                 */ +                if (conf->defrag) { +                        ret = pthread_create (&conf->defrag->th, NULL, +                                              gf_defrag_start, this); +                        if (ret) { +                                conf->defrag = NULL; +                                GF_FREE (conf->defrag); +                                kill (getpid(), SIGTERM); +                        } +                }          }          ret = 0; | 
