SOLR-12208: Renamed the autoscaling variable 'INDEX.sizeInBytes' to 'INDEX.sizeInGB'

This commit is contained in:
Noble Paul 2018-06-12 13:47:12 +10:00
parent ead05a10b1
commit 98a4dd29ef
4 changed files with 24 additions and 15 deletions

View File

@ -95,6 +95,7 @@ Other Changes
This is an internal change not yet plumbed into /update formats. This is an internal change not yet plumbed into /update formats.
AddUpdateCommand and it's relationship with DirectUpdateHandler2 was reworked substantially. (Moshe Bla, David Smiley) AddUpdateCommand and it's relationship with DirectUpdateHandler2 was reworked substantially. (Moshe Bla, David Smiley)
* SOLR-12208: Renamed the autoscaling variable 'INDEX.sizeInBytes' to 'INDEX.sizeInGB' (noble)
================== 7.4.0 ================== ================== 7.4.0 ==================
Consult the LUCENE_CHANGES.txt file for additional, low level, changes in this release. Consult the LUCENE_CHANGES.txt file for additional, low level, changes in this release.

View File

@ -41,7 +41,7 @@ import static org.apache.solr.client.solrj.cloud.autoscaling.Policy.ANY;
import static org.apache.solr.common.params.CollectionParams.CollectionAction.MOVEREPLICA; import static org.apache.solr.common.params.CollectionParams.CollectionAction.MOVEREPLICA;
public class Suggestion { public class Suggestion {
public static final String coreidxsize = "INDEX.sizeInBytes"; public static final String coreidxsize = "INDEX.sizeInGB";
static final Map<String, ConditionType> validatetypes = new HashMap<>(); static final Map<String, ConditionType> validatetypes = new HashMap<>();
@ -121,7 +121,7 @@ public class Suggestion {
IP_2("ip_2", Long.class, null, 0L, 255L), IP_2("ip_2", Long.class, null, 0L, 255L),
IP_3("ip_3", Long.class, null, 0L, 255L), IP_3("ip_3", Long.class, null, 0L, 255L),
IP_4("ip_4", Long.class, null, 0L, 255L), IP_4("ip_4", Long.class, null, 0L, 255L),
FREEDISK(ImplicitSnitch.DISK, Double.class, null, 0d, Double.MAX_VALUE, coreidxsize, Boolean.TRUE) { FREEDISK(ImplicitSnitch.DISK, Double.class, null, 0d, Double.MAX_VALUE, coreidxsize, Boolean.TRUE,null) {
@Override @Override
public Object convertVal(Object val) { public Object convertVal(Object val) {
Number value = (Number) super.validate(ImplicitSnitch.DISK, val, false); Number value = (Number) super.validate(ImplicitSnitch.DISK, val, false);
@ -206,14 +206,14 @@ public class Suggestion {
cell.val = currFreeDisk + idxSize; cell.val = currFreeDisk + idxSize;
} }
}, },
CORE_IDX(coreidxsize, Double.class, null, 0d, Double.MAX_VALUE) { CORE_IDX(coreidxsize, Double.class, null, 0d, Double.MAX_VALUE,null, false,"INDEX.sizeInBytes" ) {
@Override @Override
public Object convertVal(Object val) { public Object convertVal(Object val) {
return FREEDISK.convertVal(val); return FREEDISK.convertVal(val);
} }
}, },
NODE_ROLE(ImplicitSnitch.NODEROLE, String.class, Collections.singleton("overseer"), null, null), NODE_ROLE(ImplicitSnitch.NODEROLE, String.class, Collections.singleton("overseer"), null, null),
CORES(ImplicitSnitch.CORES, Long.class, null, 0L, Long.MAX_VALUE, null, Boolean.TRUE) { CORES(ImplicitSnitch.CORES, Long.class, null, 0L, Long.MAX_VALUE) {
@Override @Override
public void addViolatingReplicas(ViolationCtx ctx) { public void addViolatingReplicas(ViolationCtx ctx) {
for (Row r : ctx.allRows) { for (Row r : ctx.allRows) {
@ -247,9 +247,9 @@ public class Suggestion {
cell.val = cell.val == null ? 0 : ((Number) cell.val).longValue() - 1; cell.val = cell.val == null ? 0 : ((Number) cell.val).longValue() - 1;
} }
}, },
SYSLOADAVG(ImplicitSnitch.SYSLOADAVG, Double.class, null, 0d, 100d, null, Boolean.TRUE), SYSLOADAVG(ImplicitSnitch.SYSLOADAVG, Double.class, null, 0d, 100d),
HEAPUSAGE(ImplicitSnitch.HEAPUSAGE, Double.class, null, 0d, null, null, Boolean.TRUE), HEAPUSAGE(ImplicitSnitch.HEAPUSAGE, Double.class, null, 0d, null),
NUMBER("NUMBER", Long.class, null, 0L, Long.MAX_VALUE, null, Boolean.TRUE), NUMBER("NUMBER", Long.class, null, 0L, Long.MAX_VALUE),
STRING("STRING", String.class, null, null, null), STRING("STRING", String.class, null, null, null),
NODE("node", String.class, null, null, null) { NODE("node", String.class, null, null, null) {
@ -280,7 +280,7 @@ public class Suggestion {
} }
}, },
DISKTYPE(ImplicitSnitch.DISKTYPE, String.class, DISKTYPE(ImplicitSnitch.DISKTYPE, String.class,
unmodifiableSet(new HashSet(Arrays.asList("ssd", "rotational"))), null, null, null, null) { unmodifiableSet(new HashSet(Arrays.asList("ssd", "rotational"))), null, null) {
@Override @Override
public void getSuggestions(SuggestionCtx ctx) { public void getSuggestions(SuggestionCtx ctx) {
perNodeSuggestions(ctx); perNodeSuggestions(ctx);
@ -294,14 +294,15 @@ public class Suggestion {
final Boolean additive; final Boolean additive;
public final String tagName; public final String tagName;
public final String perReplicaValue; public final String perReplicaValue;
public final String metricsAttribute;
ConditionType(String tagName, Class type, Set<String> vals, Number min, Number max) { ConditionType(String tagName, Class type, Set<String> vals, Number min, Number max) {
this(tagName, type, vals, min, max, null, null); this(tagName, type, vals, min, max, null, Boolean.TRUE, null);
} }
ConditionType(String tagName, Class type, Set<String> vals, Number min, Number max, String perReplicaValue, ConditionType(String tagName, Class type, Set<String> vals, Number min, Number max, String perReplicaValue,
Boolean additive) { Boolean additive, String metricsAttribute) {
this.tagName = tagName; this.tagName = tagName;
this.type = type; this.type = type;
this.vals = vals; this.vals = vals;
@ -309,6 +310,7 @@ public class Suggestion {
this.max = max; this.max = max;
this.perReplicaValue = perReplicaValue; this.perReplicaValue = perReplicaValue;
this.additive = additive; this.additive = additive;
this.metricsAttribute = metricsAttribute;
} }
public void getSuggestions(SuggestionCtx ctx) { public void getSuggestions(SuggestionCtx ctx) {

View File

@ -122,7 +122,13 @@ public class SolrClientNodeStateProvider implements NodeStateProvider, MapWriter
Row.forEachReplica(result, r -> { Row.forEachReplica(result, r -> {
for (String key : keys) { for (String key : keys) {
if (r.getVariables().containsKey(key)) continue; if (r.getVariables().containsKey(key)) continue;
keyVsReplica.put("solr.core." + r.getCollection() + "." + r.getShard() + "." + Utils.parseMetricsReplicaName(r.getCollection(), r.getCore()) + ":" + key, new Pair<>(key, r)); String perReplicaAttrKeyPrefix = "solr.core." + r.getCollection() + "." + r.getShard() + "." + Utils.parseMetricsReplicaName(r.getCollection(), r.getCore()) + ":";
Suggestion.ConditionType tagType = Suggestion.getTagType(key);
if(tagType == null) continue;
String perReplicaValue = tagType.metricsAttribute;
perReplicaValue = perReplicaValue == null ? key : perReplicaValue;
perReplicaAttrKeyPrefix += perReplicaValue;
keyVsReplica.put(perReplicaAttrKeyPrefix, new Pair<>(key, r));
} }
}); });

View File

@ -1524,10 +1524,10 @@ public class TestPolicy extends SolrTestCaseJ4 {
" replicaInfo : {" + " replicaInfo : {" +
" node1:{}," + " node1:{}," +
" node2:{mycoll1:{" + " node2:{mycoll1:{" +
" shard1:[{r1:{type:NRT, INDEX.sizeInBytes:900}}]," + " shard1:[{r1:{type:NRT, INDEX.sizeInGB:900}}]," +
" shard2:[{r2:{type:NRT, INDEX.sizeInBytes:300}}]," + " shard2:[{r2:{type:NRT, INDEX.sizeInGB:300}}]," +
" shard3:[{r3:{type:NRT, INDEX.sizeInBytes:200}}]," + " shard3:[{r3:{type:NRT, INDEX.sizeInGB:200}}]," +
" shard4:[{r4:{type:NRT, INDEX.sizeInBytes:100}}]}}}" + " shard4:[{r4:{type:NRT, INDEX.sizeInGB:100}}]}}}" +
" nodeValues : {" + " nodeValues : {" +
" node1: { node : node1 , cores:0 , freedisk : 2000}," + " node1: { node : node1 , cores:0 , freedisk : 2000}," +
" node2: { node : node2 , cores:4 , freedisk : 500}}}"; " node2: { node : node2 , cores:4 , freedisk : 500}}}";