mirror of https://github.com/apache/druid.git
bug fix for lookup leak when we remove the last lookup from lookup tier (#8598)
* bug fix for lookup leak when we remove the last lookup from lookup tier * warnings about lookups that will never be loaded * fix unit test
This commit is contained in:
parent
a2363b6b61
commit
e1b4a3ab71
|
@ -557,16 +557,27 @@ public class LookupCoordinatorManager
|
||||||
|
|
||||||
try {
|
try {
|
||||||
List<ListenableFuture<Map.Entry>> futures = new ArrayList<>();
|
List<ListenableFuture<Map.Entry>> futures = new ArrayList<>();
|
||||||
for (Map.Entry<String, Map<String, LookupExtractorFactoryMapContainer>> tierEntry : allLookupTiers.entrySet()) {
|
|
||||||
|
|
||||||
LOG.debug("Starting lookup mgmt for tier [%s].", tierEntry.getKey());
|
Set<String> discoveredLookupTiers = lookupNodeDiscovery.getAllTiers();
|
||||||
|
|
||||||
final Map<String, LookupExtractorFactoryMapContainer> tierLookups = tierEntry.getValue();
|
// Check and Log warnings about lookups configured by user in DB but no nodes discovered to load those.
|
||||||
for (final HostAndPortWithScheme node : lookupNodeDiscovery.getNodesInTier(tierEntry.getKey())) {
|
for (String tierInDB : allLookupTiers.keySet()) {
|
||||||
|
if (!discoveredLookupTiers.contains(tierInDB) &&
|
||||||
|
!allLookupTiers.getOrDefault(tierInDB, ImmutableMap.of()).isEmpty()) {
|
||||||
|
LOG.warn("Found lookups for tier [%s] in DB, but no nodes discovered for it", tierInDB);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
for (String tier : discoveredLookupTiers) {
|
||||||
|
|
||||||
|
LOG.debug("Starting lookup mgmt for tier [%s].", tier);
|
||||||
|
|
||||||
|
final Map<String, LookupExtractorFactoryMapContainer> tierLookups = allLookupTiers.getOrDefault(tier, ImmutableMap.of());
|
||||||
|
for (final HostAndPortWithScheme node : lookupNodeDiscovery.getNodesInTier(tier)) {
|
||||||
|
|
||||||
LOG.debug(
|
LOG.debug(
|
||||||
"Starting lookup mgmt for tier [%s] and host [%s:%s:%s].",
|
"Starting lookup mgmt for tier [%s] and host [%s:%s:%s].",
|
||||||
tierEntry.getKey(),
|
tier,
|
||||||
node.getScheme(),
|
node.getScheme(),
|
||||||
node.getHostText(),
|
node.getHostText(),
|
||||||
node.getPort()
|
node.getPort()
|
||||||
|
|
|
@ -1138,6 +1138,10 @@ public class LookupCoordinatorManagerTest
|
||||||
HostAndPortWithScheme host2 = HostAndPortWithScheme.fromParts("http", "host2", 3456);
|
HostAndPortWithScheme host2 = HostAndPortWithScheme.fromParts("http", "host2", 3456);
|
||||||
|
|
||||||
EasyMock.reset(lookupNodeDiscovery);
|
EasyMock.reset(lookupNodeDiscovery);
|
||||||
|
EasyMock
|
||||||
|
.expect(lookupNodeDiscovery.getAllTiers())
|
||||||
|
.andReturn(ImmutableSet.of("tier1"))
|
||||||
|
.once();
|
||||||
EasyMock
|
EasyMock
|
||||||
.expect(lookupNodeDiscovery.getNodesInTier("tier1"))
|
.expect(lookupNodeDiscovery.getNodesInTier("tier1"))
|
||||||
.andReturn(ImmutableList.of(host1, host2))
|
.andReturn(ImmutableList.of(host1, host2))
|
||||||
|
|
Loading…
Reference in New Issue