Revert "Discovery: a more lenient wait joinThread when stopping"

This reverts commit 83d9dab798.
This commit is contained in:
Boaz Leskes 2014-11-06 11:48:35 +01:00
parent 83d9dab798
commit 9ebce349e1
2 changed files with 9 additions and 11 deletions

View File

@ -253,7 +253,6 @@ public class ZenDiscovery extends AbstractLifecycleComponent<Discovery> implemen
@Override @Override
protected void doStop() throws ElasticsearchException { protected void doStop() throws ElasticsearchException {
joinThreadControl.stop();
pingService.stop(); pingService.stop();
masterFD.stop("zen disco stop"); masterFD.stop("zen disco stop");
nodesFD.stop(); nodesFD.stop();
@ -283,6 +282,7 @@ public class ZenDiscovery extends AbstractLifecycleComponent<Discovery> implemen
} }
} }
} }
joinThreadControl.stop();
} }
@Override @Override
@ -1354,14 +1354,15 @@ public class ZenDiscovery extends AbstractLifecycleComponent<Discovery> implemen
running.set(false); running.set(false);
Thread joinThread = currentJoinThread.getAndSet(null); Thread joinThread = currentJoinThread.getAndSet(null);
if (joinThread != null) { if (joinThread != null) {
for (int i = 0; i < 10 && joinThread.isAlive(); i++) { try {
joinThread.interrupt(); joinThread.interrupt();
try { } catch (Exception e) {
joinThread.join(200); // ignore
} catch (InterruptedException e) { }
Thread.currentThread().interrupt(); try {
return; joinThread.join(10000);
} } catch (InterruptedException e) {
Thread.currentThread().interrupt();
} }
} }
} }

View File

@ -373,9 +373,6 @@ public class UnicastZenPing extends AbstractLifecycleComponent<ZenPing> implemen
} catch (ConnectTransportException e) { } catch (ConnectTransportException e) {
// can't connect to the node - this is a more common path! // can't connect to the node - this is a more common path!
logger.trace("[{}] failed to connect to {}", e, sendPingsHandler.id(), finalNodeToSend); logger.trace("[{}] failed to connect to {}", e, sendPingsHandler.id(), finalNodeToSend);
} catch (RemoteTransportException e) {
// something went wrong on the other side
logger.debug("[{}] received a remote error as a response to ping {}", e, sendPingsHandler.id(), finalNodeToSend);
} catch (Throwable e) { } catch (Throwable e) {
logger.warn("[{}] failed send ping to {}", e, sendPingsHandler.id(), finalNodeToSend); logger.warn("[{}] failed send ping to {}", e, sendPingsHandler.id(), finalNodeToSend);
} finally { } finally {