forked from opensearch-project/geospatial
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Add restoring event listener (opensearch-project#328)
In the listener, we trigger a geoip data update Signed-off-by: Heemin Kim <[email protected]>
- Loading branch information
Showing
9 changed files
with
431 additions
and
6 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
112 changes: 112 additions & 0 deletions
112
src/main/java/org/opensearch/geospatial/ip2geo/listener/Ip2GeoListener.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,112 @@ | ||
/* | ||
* Copyright OpenSearch Contributors | ||
* SPDX-License-Identifier: Apache-2.0 | ||
*/ | ||
|
||
package org.opensearch.geospatial.ip2geo.listener; | ||
|
||
import java.io.IOException; | ||
import java.time.Instant; | ||
import java.time.temporal.ChronoUnit; | ||
import java.util.List; | ||
|
||
import lombok.AllArgsConstructor; | ||
import lombok.extern.log4j.Log4j2; | ||
|
||
import org.opensearch.action.ActionListener; | ||
import org.opensearch.action.bulk.BulkResponse; | ||
import org.opensearch.cluster.ClusterChangedEvent; | ||
import org.opensearch.cluster.ClusterStateListener; | ||
import org.opensearch.cluster.RestoreInProgress; | ||
import org.opensearch.cluster.node.DiscoveryNode; | ||
import org.opensearch.cluster.service.ClusterService; | ||
import org.opensearch.common.component.AbstractLifecycleComponent; | ||
import org.opensearch.common.inject.Inject; | ||
import org.opensearch.geospatial.ip2geo.common.DatasourceFacade; | ||
import org.opensearch.geospatial.ip2geo.jobscheduler.Datasource; | ||
import org.opensearch.geospatial.ip2geo.jobscheduler.DatasourceExtension; | ||
import org.opensearch.geospatial.ip2geo.jobscheduler.DatasourceTask; | ||
import org.opensearch.jobscheduler.spi.schedule.IntervalSchedule; | ||
import org.opensearch.threadpool.ThreadPool; | ||
|
||
@Log4j2 | ||
@AllArgsConstructor(onConstructor = @__(@Inject)) | ||
public class Ip2GeoListener extends AbstractLifecycleComponent implements ClusterStateListener { | ||
private static final int SCHEDULE_IN_MIN = 15; | ||
private static final int DELAY_IN_MILLIS = 10000; | ||
private final ClusterService clusterService; | ||
private final ThreadPool threadPool; | ||
private final DatasourceFacade datasourceFacade; | ||
|
||
@Override | ||
public void clusterChanged(final ClusterChangedEvent event) { | ||
if (event.localNodeClusterManager() == false) { | ||
return; | ||
} | ||
|
||
for (RestoreInProgress.Entry entry : event.state().custom(RestoreInProgress.TYPE, RestoreInProgress.EMPTY)) { | ||
if (RestoreInProgress.State.SUCCESS.equals(entry.state()) == false) { | ||
continue; | ||
} | ||
|
||
if (entry.indices().stream().anyMatch(index -> DatasourceExtension.JOB_INDEX_NAME.equals(index)) == false) { | ||
continue; | ||
} | ||
|
||
threadPool.generic().submit(() -> forceUpdateGeoIpData()); | ||
} | ||
} | ||
|
||
private void forceUpdateGeoIpData() { | ||
datasourceFacade.getAllDatasources(new ActionListener<>() { | ||
@Override | ||
public void onResponse(final List<Datasource> datasources) { | ||
datasources.stream().forEach(Ip2GeoListener.this::scheduleForceUpdate); | ||
datasourceFacade.updateDatasource(datasources, new ActionListener<>() { | ||
@Override | ||
public void onResponse(final BulkResponse bulkItemResponses) { | ||
log.info("Datasources are updated for cleanup"); | ||
} | ||
|
||
@Override | ||
public void onFailure(final Exception e) { | ||
log.error("Failed to update datasource for cleanup after restoring", e); | ||
} | ||
}); | ||
} | ||
|
||
@Override | ||
public void onFailure(final Exception e) { | ||
log.error("Failed to get datasource after restoring", e); | ||
} | ||
}); | ||
} | ||
|
||
/** | ||
* Give a delay so that job scheduler can schedule the job right after the delay. Otherwise, it schedules | ||
* the job after specified update interval. | ||
*/ | ||
private void scheduleForceUpdate(Datasource datasource) { | ||
IntervalSchedule schedule = new IntervalSchedule(Instant.now(), SCHEDULE_IN_MIN, ChronoUnit.MINUTES, DELAY_IN_MILLIS); | ||
datasource.resetDatabase(); | ||
datasource.setSystemSchedule(schedule); | ||
datasource.setTask(DatasourceTask.ALL); | ||
} | ||
|
||
@Override | ||
protected void doStart() { | ||
if (DiscoveryNode.isClusterManagerNode(clusterService.getSettings())) { | ||
clusterService.addListener(this); | ||
} | ||
} | ||
|
||
@Override | ||
protected void doStop() { | ||
clusterService.removeListener(this); | ||
} | ||
|
||
@Override | ||
protected void doClose() throws IOException { | ||
|
||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.