HBASE-4363 [replication] ReplicationSource won't close if failing
to contact the sink (JD and Lars Hofhansl) git-svn-id: https://svn.apache.org/repos/asf/hbase/trunk@1171286 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
067b987b3c
commit
419490d69b
|
@ -266,6 +266,8 @@ Release 0.91.0 - Unreleased
|
|||
HBASE-4351 If from Admin we try to unassign a region forcefully,
|
||||
though a valid region name is given the master is not able
|
||||
to identify the region to unassign (Ramkrishna)
|
||||
HBASE-4363 [replication] ReplicationSource won't close if failing
|
||||
to contact the sink (JD and Lars Hofhansl)
|
||||
|
||||
IMPROVEMENTS
|
||||
HBASE-3290 Max Compaction Size (Nicolas Spiegelberg via Stack)
|
||||
|
|
|
@ -240,7 +240,7 @@ public class ReplicationSource extends Thread
|
|||
public void run() {
|
||||
connectToPeers();
|
||||
// We were stopped while looping to connect to sinks, just abort
|
||||
if (this.stopper.isStopped()) {
|
||||
if (!this.isActive()) {
|
||||
return;
|
||||
}
|
||||
// delay this until we are in an asynchronous thread
|
||||
|
@ -265,7 +265,7 @@ public class ReplicationSource extends Thread
|
|||
}
|
||||
int sleepMultiplier = 1;
|
||||
// Loop until we close down
|
||||
while (!stopper.isStopped() && this.running) {
|
||||
while (isActive()) {
|
||||
// Sleep until replication is enabled again
|
||||
if (!this.replicating.get() || !this.sourceEnabled.get()) {
|
||||
if (sleepForRetries("Replication is disabled", sleepMultiplier)) {
|
||||
|
@ -348,7 +348,7 @@ public class ReplicationSource extends Thread
|
|||
// If we didn't get anything to replicate, or if we hit a IOE,
|
||||
// wait a bit and retry.
|
||||
// But if we need to stop, don't bother sleeping
|
||||
if (!stopper.isStopped() && (gotIOE || currentNbEntries == 0)) {
|
||||
if (this.isActive() && (gotIOE || currentNbEntries == 0)) {
|
||||
this.manager.logPositionAndCleanOldLogs(this.currentPath,
|
||||
this.peerClusterZnode, this.position, queueRecovered);
|
||||
if (sleepForRetries("Nothing to replicate", sleepMultiplier)) {
|
||||
|
@ -428,7 +428,8 @@ public class ReplicationSource extends Thread
|
|||
|
||||
private void connectToPeers() {
|
||||
// Connect to peer cluster first, unless we have to stop
|
||||
while (!this.stopper.isStopped() && this.currentPeers.size() == 0) {
|
||||
while (this.isActive() && this.currentPeers.size() == 0) {
|
||||
|
||||
try {
|
||||
chooseSinks();
|
||||
Thread.sleep(this.sleepForRetries);
|
||||
|
@ -586,7 +587,7 @@ public class ReplicationSource extends Thread
|
|||
LOG.warn("Was given 0 edits to ship");
|
||||
return;
|
||||
}
|
||||
while (!this.stopper.isStopped()) {
|
||||
while (this.isActive()) {
|
||||
try {
|
||||
HRegionInterface rrs = getRS();
|
||||
LOG.debug("Replicating " + currentNbEntries);
|
||||
|
@ -613,6 +614,7 @@ public class ReplicationSource extends Thread
|
|||
}
|
||||
try {
|
||||
boolean down;
|
||||
// Spin while the slave is down and we're not asked to shutdown/close
|
||||
do {
|
||||
down = isSlaveDown();
|
||||
if (down) {
|
||||
|
@ -622,7 +624,7 @@ public class ReplicationSource extends Thread
|
|||
chooseSinks();
|
||||
}
|
||||
}
|
||||
} while (!this.stopper.isStopped() && down);
|
||||
} while (this.isActive() && down );
|
||||
} catch (InterruptedException e) {
|
||||
LOG.debug("Interrupted while trying to contact the peer cluster");
|
||||
} catch (KeeperException e) {
|
||||
|
@ -742,6 +744,10 @@ public class ReplicationSource extends Thread
|
|||
this.sourceEnabled.set(status);
|
||||
}
|
||||
|
||||
private boolean isActive() {
|
||||
return !this.stopper.isStopped() && this.running;
|
||||
}
|
||||
|
||||
/**
|
||||
* Comparator used to compare logs together based on their start time
|
||||
*/
|
||||
|
|
Loading…
Reference in New Issue