mirror of https://github.com/apache/lucene.git
SOLR-12208: Renamed the autoscaling variable 'INDEX.sizeInBytes' to 'INDEX.sizeInGB'
This commit is contained in:
parent
ead05a10b1
commit
98a4dd29ef
|
@ -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.
|
||||||
|
|
|
@ -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) {
|
||||||
|
|
|
@ -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));
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
|
@ -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}}}";
|
||||||
|
|
Loading…
Reference in New Issue