[ https://issues.apache.org/jira/browse/CURATOR-518?focusedWorklogId=849110&page=com.atlassian.jira.plugin.system.issuetabpanels:worklog-tabpanel#worklog-849110 ]
ASF GitHub Bot logged work on CURATOR-518: ------------------------------------------ Author: ASF GitHub Bot Created on: 04/Mar/23 15:27 Start Date: 04/Mar/23 15:27 Worklog Time Spent: 10m Work Description: kezhuw commented on code in PR #446: URL: https://github.com/apache/curator/pull/446#discussion_r1125491607 ########## curator-recipes/src/main/java/org/apache/curator/framework/recipes/leader/LeaderSelector.java: ########## @@ -237,13 +242,15 @@ private synchronized boolean internalRequeue() if ( !isQueued && (state.get() == State.STARTED) ) { isQueued = true; - Future<Void> task = executorService.submit(new Callable<Void>() + Future<?> oldTask = ourTask; + ourTask = executorService.submit(new Callable<Void>() { @Override public Void call() throws Exception { try { + waitTaskDone(oldTask, Duration.ofMillis(500), Duration.ofSeconds(5)); Review Comment: It is caused by my fix in `cancelElection`. Old code won't cause simultaneous elections, so didn't need such wait. Issue Time Tracking ------------------- Worklog Id: (was: 849110) Time Spent: 1h 10m (was: 1h) > Curator. LeaderSelector. Two successive calls to interruptLeadership() will > break autoRequeue. > ---------------------------------------------------------------------------------------------- > > Key: CURATOR-518 > URL: https://issues.apache.org/jira/browse/CURATOR-518 > Project: Apache Curator > Issue Type: Improvement > Components: Recipes > Affects Versions: 4.0.1, 4.2.0 > Environment: Windows 8, JRE 1.8.0_181 > Reporter: Bulatov Oleg > Priority: Major > Labels: newbie > Time Spent: 1h 10m > Remaining Estimate: 0h > > h1. Curator. LeaderSelector. Two successive calls to interruptLeadership() > will break autoRequeue > If we set autoRequeue to TRUE. But during execution interruptLeadership() > will be called from another thread before internalRequeue() completed its > work. Then it will break recursive call to internalRequeue(), so that client > will not ask for leadership and get stuck. > We can solve this problem if we check hasLeadership() before calling > interruptLeadership(). But it is strange that such check curator library does > not do internally. -- This message was sent by Atlassian Jira (v8.20.10#820010)