mirror of https://github.com/apache/lucene.git
added testcase for sysprop.
This commit is contained in:
parent
5b066e091c
commit
621b46179c
|
@ -82,12 +82,17 @@ public class TestPolicyCloud extends SolrCloudTestCase {
|
||||||
}
|
}
|
||||||
Thread.sleep(100);
|
Thread.sleep(100);
|
||||||
}
|
}
|
||||||
val = provider.getNodeValues(overseerNode, Arrays.asList("nodeRole", "ip_1","ip_2","ip_3", "ip_4", "sysprop.java.version"));
|
val = provider.getNodeValues(overseerNode, Arrays.asList(
|
||||||
|
"nodeRole",
|
||||||
|
"ip_1","ip_2","ip_3", "ip_4",
|
||||||
|
"sysprop.java.version",
|
||||||
|
"sysprop.java.vendor"));
|
||||||
assertEquals("overseer", val.get("nodeRole"));
|
assertEquals("overseer", val.get("nodeRole"));
|
||||||
assertNotNull( val.get("ip_1"));
|
assertNotNull( val.get("ip_1"));
|
||||||
assertNotNull( val.get("ip_2"));
|
assertNotNull( val.get("ip_2"));
|
||||||
assertNotNull( val.get("ip_3"));
|
assertNotNull( val.get("ip_3"));
|
||||||
assertNotNull( val.get("ip_4"));
|
assertNotNull( val.get("ip_4"));
|
||||||
// assertNotNull( val.get("sysprop.java.version"));
|
assertNotNull( val.get("sysprop.java.version"));
|
||||||
|
assertNotNull( val.get("sysprop.java.vendor"));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -21,6 +21,7 @@ package org.apache.solr.client.solrj.impl;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.lang.invoke.MethodHandles;
|
import java.lang.invoke.MethodHandles;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
import java.util.Arrays;
|
||||||
import java.util.Collection;
|
import java.util.Collection;
|
||||||
import java.util.Collections;
|
import java.util.Collections;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
|
@ -53,16 +54,16 @@ import org.apache.zookeeper.data.Stat;
|
||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
import org.slf4j.LoggerFactory;
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
/**Class that implements {@link ClusterStateProvider} accepting a SolrClient
|
/**
|
||||||
*
|
* Class that implements {@link ClusterStateProvider} accepting a SolrClient
|
||||||
*/
|
*/
|
||||||
public class SolrClientDataProvider implements ClusterDataProvider, MapWriter {
|
public class SolrClientDataProvider implements ClusterDataProvider, MapWriter {
|
||||||
|
|
||||||
private final CloudSolrClient solrClient;
|
private final CloudSolrClient solrClient;
|
||||||
private Set<String> liveNodes;
|
private Set<String> liveNodes;
|
||||||
private Map<String,Object> snitchSession = new HashMap<>();
|
private Map<String, Object> snitchSession = new HashMap<>();
|
||||||
private final Map<String, Map<String, Map<String, List<ReplicaInfo>>>> data = new HashMap<>();
|
private final Map<String, Map<String, Map<String, List<ReplicaInfo>>>> data = new HashMap<>();
|
||||||
private Map<String,Map> nodeVsTags = new HashMap<>();
|
private Map<String, Map> nodeVsTags = new HashMap<>();
|
||||||
|
|
||||||
public SolrClientDataProvider(CloudSolrClient solrClient) {
|
public SolrClientDataProvider(CloudSolrClient solrClient) {
|
||||||
this.solrClient = solrClient;
|
this.solrClient = solrClient;
|
||||||
|
@ -80,7 +81,7 @@ public class SolrClientDataProvider implements ClusterDataProvider, MapWriter {
|
||||||
if (collData == null) nodeData.put(collName, collData = new HashMap<>());
|
if (collData == null) nodeData.put(collName, collData = new HashMap<>());
|
||||||
List<ReplicaInfo> replicas = collData.get(shard);
|
List<ReplicaInfo> replicas = collData.get(shard);
|
||||||
if (replicas == null) collData.put(shard, replicas = new ArrayList<>());
|
if (replicas == null) collData.put(shard, replicas = new ArrayList<>());
|
||||||
replicas.add(new ReplicaInfo(replica.getName(), collName , shard, new HashMap<>()));
|
replicas.add(new ReplicaInfo(replica.getName(), collName, shard, new HashMap<>()));
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
@ -93,7 +94,7 @@ public class SolrClientDataProvider implements ClusterDataProvider, MapWriter {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Map<String, Object> getNodeValues(String node, Collection<String> tags) {
|
public Map<String, Object> getNodeValues(String node, Collection<String> tags) {
|
||||||
AutoScalingSnitch snitch = new AutoScalingSnitch();
|
AutoScalingSnitch snitch = new AutoScalingSnitch();
|
||||||
ClientSnitchCtx ctx = new ClientSnitchCtx(null, node, snitchSession, solrClient);
|
ClientSnitchCtx ctx = new ClientSnitchCtx(null, node, snitchSession, solrClient);
|
||||||
snitch.getTags(node, new HashSet<>(tags), ctx);
|
snitch.getTags(node, new HashSet<>(tags), ctx);
|
||||||
nodeVsTags.put(node, ctx.getTags());
|
nodeVsTags.put(node, ctx.getTags());
|
||||||
|
@ -165,6 +166,7 @@ public class SolrClientDataProvider implements ClusterDataProvider, MapWriter {
|
||||||
@Override
|
@Override
|
||||||
protected void getRemoteInfo(String solrNode, Set<String> requestedTags, SnitchContext ctx) {
|
protected void getRemoteInfo(String solrNode, Set<String> requestedTags, SnitchContext ctx) {
|
||||||
ClientSnitchCtx snitchContext = (ClientSnitchCtx) ctx;
|
ClientSnitchCtx snitchContext = (ClientSnitchCtx) ctx;
|
||||||
|
readSysProps(solrNode, requestedTags, snitchContext);
|
||||||
Set<String> groups = new HashSet<>();
|
Set<String> groups = new HashSet<>();
|
||||||
List<String> prefixes = new ArrayList<>();
|
List<String> prefixes = new ArrayList<>();
|
||||||
if (requestedTags.contains(DISK)) {
|
if (requestedTags.contains(DISK)) {
|
||||||
|
@ -179,43 +181,75 @@ public class SolrClientDataProvider implements ClusterDataProvider, MapWriter {
|
||||||
groups.add("solr.jvm");
|
groups.add("solr.jvm");
|
||||||
prefixes.add("os.systemLoadAverage");
|
prefixes.add("os.systemLoadAverage");
|
||||||
}
|
}
|
||||||
if (requestedTags.contains(HEAPUSAGE)) {
|
if (requestedTags.contains(HEAPUSAGE)) {
|
||||||
groups.add("solr.jvm");
|
groups.add("solr.jvm");
|
||||||
prefixes.add("memory.heap.usage");
|
prefixes.add("memory.heap.usage");
|
||||||
}
|
}
|
||||||
if(groups.isEmpty() || prefixes.isEmpty()) return;
|
if (groups.isEmpty() || prefixes.isEmpty()) return;
|
||||||
|
|
||||||
ModifiableSolrParams params = new ModifiableSolrParams();
|
ModifiableSolrParams params = new ModifiableSolrParams();
|
||||||
params.add("group", StrUtils.join(groups, ','));
|
params.add("group", StrUtils.join(groups, ','));
|
||||||
params.add("prefix", StrUtils.join(prefixes,','));
|
params.add("prefix", StrUtils.join(prefixes, ','));
|
||||||
|
|
||||||
try {
|
try {
|
||||||
SimpleSolrResponse rsp = snitchContext.invoke(solrNode, CommonParams.METRICS_PATH, params);
|
SimpleSolrResponse rsp = snitchContext.invoke(solrNode, CommonParams.METRICS_PATH, params);
|
||||||
Map m = rsp.nl.asMap(4);
|
Map m = rsp.nl.asMap(4);
|
||||||
if(requestedTags.contains(DISK)){
|
if (requestedTags.contains(DISK)) {
|
||||||
Number n = (Number) Utils.getObjectByPath(m,true, "metrics/solr.node/CONTAINER.fs.usableSpace/value");
|
Number n = (Number) Utils.getObjectByPath(m, true, "metrics/solr.node/CONTAINER.fs.usableSpace/value");
|
||||||
if(n != null) ctx.getTags().put(DISK, n.doubleValue() / 1024.0d / 1024.0d / 1024.0d);
|
if (n != null) ctx.getTags().put(DISK, n.doubleValue() / 1024.0d / 1024.0d / 1024.0d);
|
||||||
}
|
}
|
||||||
if(requestedTags.contains(CORES)){
|
if (requestedTags.contains(CORES)) {
|
||||||
int count = 0;
|
int count = 0;
|
||||||
Map cores = (Map) m.get("metrics");
|
Map cores = (Map) m.get("metrics");
|
||||||
for (Object o : cores.keySet()) {
|
for (Object o : cores.keySet()) {
|
||||||
if(o.toString().startsWith("solr.core.")) count++;
|
if (o.toString().startsWith("solr.core.")) count++;
|
||||||
}
|
}
|
||||||
ctx.getTags().put(CORES, count);
|
ctx.getTags().put(CORES, count);
|
||||||
}
|
}
|
||||||
if (requestedTags.contains(SYSLOADAVG)) {
|
if (requestedTags.contains(SYSLOADAVG)) {
|
||||||
Number n = (Number) Utils.getObjectByPath(m, true, "metrics/solr.jvm/os.systemLoadAverage/value");
|
Number n = (Number) Utils.getObjectByPath(m, true, "metrics/solr.jvm/os.systemLoadAverage/value");
|
||||||
if (n != null) ctx.getTags().put(SYSLOADAVG, n.doubleValue() * 100.0d);
|
if (n != null) ctx.getTags().put(SYSLOADAVG, n.doubleValue() * 100.0d);
|
||||||
}
|
}
|
||||||
if (requestedTags.contains(HEAPUSAGE)) {
|
if (requestedTags.contains(HEAPUSAGE)) {
|
||||||
Number n = (Number) Utils.getObjectByPath(m, true, "metrics/solr.jvm/memory.heap.usage/value");
|
Number n = (Number) Utils.getObjectByPath(m, true, "metrics/solr.jvm/memory.heap.usage/value");
|
||||||
if (n != null) ctx.getTags().put(HEAPUSAGE, n.doubleValue() * 100.0d);
|
if (n != null) ctx.getTags().put(HEAPUSAGE, n.doubleValue() * 100.0d);
|
||||||
}
|
}
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
throw new SolrException(SolrException.ErrorCode.SERVER_ERROR, "", e);
|
throw new SolrException(SolrException.ErrorCode.SERVER_ERROR, "", e);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void readSysProps(String solrNode, Set<String> requestedTags, ClientSnitchCtx snitchContext) {
|
||||||
|
List<String> prefixes = null;
|
||||||
|
ModifiableSolrParams params;
|
||||||
|
List<String> sysProp = null;
|
||||||
|
for (String tag : requestedTags) {
|
||||||
|
if (!tag.startsWith(SYSPROP)) continue;
|
||||||
|
if (sysProp == null) {
|
||||||
|
prefixes = new ArrayList<>();
|
||||||
|
sysProp = new ArrayList<>();
|
||||||
|
prefixes.add("system.properties");
|
||||||
|
}
|
||||||
|
sysProp.add(tag.substring(SYSPROP.length()));
|
||||||
|
}
|
||||||
|
|
||||||
|
if (sysProp == null) return;
|
||||||
|
params = new ModifiableSolrParams();
|
||||||
|
params.add("prefix", StrUtils.join(prefixes, ','));
|
||||||
|
for (String s : sysProp) params.add("property", s);
|
||||||
|
try {
|
||||||
|
SimpleSolrResponse rsp = snitchContext.invoke(solrNode, CommonParams.METRICS_PATH, params);
|
||||||
|
Map m = rsp.nl.asMap(6);
|
||||||
|
for (String s : sysProp) {
|
||||||
|
Object v = Utils.getObjectByPath(m, true,
|
||||||
|
Arrays.asList("metrics", "solr.jvm", "system.properties", "value", s));
|
||||||
|
if (v != null) snitchContext.getTags().put("sysprop." + s, v);
|
||||||
|
}
|
||||||
|
|
||||||
|
} catch (Exception e) {
|
||||||
|
throw new SolrException(SolrException.ErrorCode.SERVER_ERROR, "", e);
|
||||||
|
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue