![JAR search and dependency download from the Maven repository](/logo.png)
eu.xenit.alfred.telemetry.solr.monitoring.binder.SolrFTSMetrics Maven / Gradle / Ivy
package eu.xenit.alfred.telemetry.solr.monitoring.binder;
import io.micrometer.core.instrument.Gauge;
import io.micrometer.core.instrument.MeterRegistry;
import io.micrometer.core.instrument.Tags;
import io.micrometer.core.instrument.binder.MeterBinder;
import java.util.Map.Entry;
import java.util.Set;
import org.alfresco.solr.AlfrescoCoreAdminHandler;
import org.alfresco.solr.SolrInformationServer;
import org.alfresco.solr.tracker.TrackerRegistry;
import org.apache.solr.common.util.NamedList;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
public class SolrFTSMetrics implements MeterBinder {
private AlfrescoCoreAdminHandler coreAdminHandler;
private MeterRegistry registry;
private static final Logger logger = LoggerFactory.getLogger(SolrFTSMetrics.class);
public SolrFTSMetrics(AlfrescoCoreAdminHandler coreAdminHandler) {
this.coreAdminHandler = coreAdminHandler;
}
private void registerFTSMetrics() {
logger.info("Registering FTS metrics");
TrackerRegistry trackerRegistry = coreAdminHandler.getTrackerRegistry();
while (trackerRegistry.getCoreNames().size() == 0) {
logger.error("Solr did not start tracking yet, waiting 10sec");
try {
Thread.currentThread().sleep(10_000);
trackerRegistry = coreAdminHandler.getTrackerRegistry();
} catch (InterruptedException e) {
logger.error("Fail to wait 10 sec ",e);
}
}
Set coreNames = coreAdminHandler.getTrackerRegistry().getCoreNames();
for (String coreName : coreNames) {
NamedList
© 2015 - 2025 Weber Informatics LLC | Privacy Policy