mirror of https://github.com/apache/druid.git
MSQ: Controller checker should check for "closed" only. (#16161)
* MSQ: Controller checker should check for "closed" only. Currently, the worker's controller checker will exit the worker if the controller location is "closed" (no longer running) or if its location is empty (i.e. location unknown). This patch changes to only exit on "closed". We shouldn't exit on empty location, because that may happen if the Overlord is slow to acknowledge the location of a task. * Fix test.
This commit is contained in:
parent
e7cf8299ce
commit
2b23d0b5b5
|
@ -190,7 +190,9 @@ public class IndexerWorkerContext implements WorkerContext
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (controllerLocations.isClosed() || controllerLocations.getLocations().isEmpty()) {
|
// Note: don't exit on empty location, because that may happen if the Overlord is slow to acknowledge the
|
||||||
|
// location of a task. Only exit on "closed", because that happens only if the task is really no longer running.
|
||||||
|
if (controllerLocations.isClosed()) {
|
||||||
log.warn(
|
log.warn(
|
||||||
"Periodic fetch of controller location returned [%s]. Worker task [%s] will exit.",
|
"Periodic fetch of controller location returned [%s]. Worker task [%s] will exit.",
|
||||||
controllerLocations,
|
controllerLocations,
|
||||||
|
|
|
@ -54,20 +54,6 @@ public class IndexerWorkerContextTest
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testControllerCheckerRunnableExitsWhenEmptyStatus()
|
|
||||||
{
|
|
||||||
final ServiceLocator controllerLocatorMock = Mockito.mock(ServiceLocator.class);
|
|
||||||
Mockito.when(controllerLocatorMock.locate())
|
|
||||||
.thenReturn(Futures.immediateFuture(ServiceLocations.forLocations(Collections.emptySet())));
|
|
||||||
|
|
||||||
final Worker workerMock = Mockito.mock(Worker.class);
|
|
||||||
|
|
||||||
indexerWorkerContext.controllerCheckerRunnable(controllerLocatorMock, workerMock);
|
|
||||||
Mockito.verify(controllerLocatorMock, Mockito.times(1)).locate();
|
|
||||||
Mockito.verify(workerMock, Mockito.times(1)).controllerFailed();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testControllerCheckerRunnableExitsOnlyWhenClosedStatus()
|
public void testControllerCheckerRunnableExitsOnlyWhenClosedStatus()
|
||||||
{
|
{
|
||||||
|
@ -76,12 +62,13 @@ public class IndexerWorkerContextTest
|
||||||
.thenReturn(Futures.immediateFuture(ServiceLocations.forLocation(new ServiceLocation("h", 1, -1, "/"))))
|
.thenReturn(Futures.immediateFuture(ServiceLocations.forLocation(new ServiceLocation("h", 1, -1, "/"))))
|
||||||
// Done to check the behavior of the runnable, the situation of exiting after success might not occur actually
|
// Done to check the behavior of the runnable, the situation of exiting after success might not occur actually
|
||||||
.thenReturn(Futures.immediateFuture(ServiceLocations.forLocation(new ServiceLocation("h", 1, -1, "/"))))
|
.thenReturn(Futures.immediateFuture(ServiceLocations.forLocation(new ServiceLocation("h", 1, -1, "/"))))
|
||||||
|
.thenReturn(Futures.immediateFuture(ServiceLocations.forLocations(Collections.emptySet())))
|
||||||
.thenReturn(Futures.immediateFuture(ServiceLocations.closed()));
|
.thenReturn(Futures.immediateFuture(ServiceLocations.closed()));
|
||||||
|
|
||||||
final Worker workerMock = Mockito.mock(Worker.class);
|
final Worker workerMock = Mockito.mock(Worker.class);
|
||||||
|
|
||||||
indexerWorkerContext.controllerCheckerRunnable(controllerLocatorMock, workerMock);
|
indexerWorkerContext.controllerCheckerRunnable(controllerLocatorMock, workerMock);
|
||||||
Mockito.verify(controllerLocatorMock, Mockito.times(3)).locate();
|
Mockito.verify(controllerLocatorMock, Mockito.times(4)).locate();
|
||||||
Mockito.verify(workerMock, Mockito.times(1)).controllerFailed();
|
Mockito.verify(workerMock, Mockito.times(1)).controllerFailed();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue