Faster mapList, bugfixes, remove composite buffers
This commit is contained in:
parent
81f1c5643d
commit
af7c3dfd65
2
pom.xml
2
pom.xml
@ -14,7 +14,7 @@
|
|||||||
<dbengine.ci>false</dbengine.ci>
|
<dbengine.ci>false</dbengine.ci>
|
||||||
<micrometer.version>1.9.5</micrometer.version>
|
<micrometer.version>1.9.5</micrometer.version>
|
||||||
<lucene.version>9.5.0</lucene.version>
|
<lucene.version>9.5.0</lucene.version>
|
||||||
<rocksdb.version>7.9.2</rocksdb.version>
|
<rocksdb.version>7.10.2</rocksdb.version>
|
||||||
<junit.jupiter.version>5.9.0</junit.jupiter.version>
|
<junit.jupiter.version>5.9.0</junit.jupiter.version>
|
||||||
<data.generator.version>1.0.258</data.generator.version>
|
<data.generator.version>1.0.258</data.generator.version>
|
||||||
</properties>
|
</properties>
|
||||||
|
@ -1,5 +1,7 @@
|
|||||||
package it.cavallium.dbengine.client.query;
|
package it.cavallium.dbengine.client.query;
|
||||||
|
|
||||||
|
import static it.cavallium.dbengine.database.LLUtils.mapList;
|
||||||
|
|
||||||
import it.cavallium.dbengine.client.query.current.data.BooleanQuery;
|
import it.cavallium.dbengine.client.query.current.data.BooleanQuery;
|
||||||
import it.cavallium.dbengine.client.query.current.data.BooleanQueryPart;
|
import it.cavallium.dbengine.client.query.current.data.BooleanQueryPart;
|
||||||
import it.cavallium.dbengine.client.query.current.data.Occur;
|
import it.cavallium.dbengine.client.query.current.data.Occur;
|
||||||
@ -86,11 +88,7 @@ public class QueryUtils {
|
|||||||
}
|
}
|
||||||
org.apache.lucene.search.SynonymQuery synonymQuery = (org.apache.lucene.search.SynonymQuery) luceneQuery;
|
org.apache.lucene.search.SynonymQuery synonymQuery = (org.apache.lucene.search.SynonymQuery) luceneQuery;
|
||||||
return SynonymQuery.of(field,
|
return SynonymQuery.of(field,
|
||||||
synonymQuery
|
mapList(synonymQuery.getTerms(), term -> TermAndBoost.of(QueryParser.toQueryTerm(term), 1))
|
||||||
.getTerms()
|
|
||||||
.stream()
|
|
||||||
.map(term -> TermAndBoost.of(QueryParser.toQueryTerm(term), 1))
|
|
||||||
.toList()
|
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
package it.cavallium.dbengine.database;
|
package it.cavallium.dbengine.database;
|
||||||
|
|
||||||
|
import static it.cavallium.dbengine.database.LLUtils.mapList;
|
||||||
import static it.cavallium.dbengine.lucene.LuceneUtils.getLuceneIndexId;
|
import static it.cavallium.dbengine.lucene.LuceneUtils.getLuceneIndexId;
|
||||||
import static it.cavallium.dbengine.utils.StreamUtils.LUCENE_SCHEDULER;
|
import static it.cavallium.dbengine.utils.StreamUtils.LUCENE_SCHEDULER;
|
||||||
import static it.cavallium.dbengine.utils.StreamUtils.collect;
|
import static it.cavallium.dbengine.utils.StreamUtils.collect;
|
||||||
@ -174,11 +175,11 @@ public class LLMultiLuceneIndex implements LLLuceneIndex {
|
|||||||
@NotNull List<Query> queries,
|
@NotNull List<Query> queries,
|
||||||
@Nullable Query normalizationQuery,
|
@Nullable Query normalizationQuery,
|
||||||
BucketParams bucketParams) {
|
BucketParams bucketParams) {
|
||||||
return mergeShards(luceneIndicesSet.stream().map(luceneIndex -> luceneIndex.computeBuckets(snapshot,
|
return mergeShards(mapList(luceneIndicesSet, luceneIndex -> luceneIndex.computeBuckets(snapshot,
|
||||||
queries,
|
queries,
|
||||||
normalizationQuery,
|
normalizationQuery,
|
||||||
bucketParams
|
bucketParams
|
||||||
)).toList());
|
)));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -513,30 +513,6 @@ public class LLUtils {
|
|||||||
return Buf.copyOf(array);
|
return Buf.copyOf(array);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
public static Buf compositeBuffer(Buf buffer) {
|
|
||||||
return buffer;
|
|
||||||
}
|
|
||||||
|
|
||||||
@NotNull
|
|
||||||
public static Buf compositeBuffer(Buf buffer1, Buf buffer2) {
|
|
||||||
// todo: create a composite buffer without allocating a new array
|
|
||||||
var out = Buf.create(buffer1.size() + buffer2.size());
|
|
||||||
out.addAll(buffer1);
|
|
||||||
out.addAll(buffer2);
|
|
||||||
return out;
|
|
||||||
}
|
|
||||||
|
|
||||||
@NotNull
|
|
||||||
public static Buf compositeBuffer(Buf buffer1, Buf buffer2, Buf buffer3) {
|
|
||||||
// todo: create a composite buffer without allocating a new array
|
|
||||||
var out = Buf.create(buffer1.size() + buffer2.size());
|
|
||||||
out.addAll(buffer1);
|
|
||||||
out.addAll(buffer2);
|
|
||||||
out.addAll(buffer3);
|
|
||||||
return out;
|
|
||||||
}
|
|
||||||
|
|
||||||
public static <T> T resolveDelta(Delta<T> delta, UpdateReturnMode updateReturnMode) {
|
public static <T> T resolveDelta(Delta<T> delta, UpdateReturnMode updateReturnMode) {
|
||||||
return switch (updateReturnMode) {
|
return switch (updateReturnMode) {
|
||||||
case GET_NEW_VALUE -> delta.current();
|
case GET_NEW_VALUE -> delta.current();
|
||||||
@ -666,9 +642,10 @@ public class LLUtils {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public static <T, U> List<U> mapList(List<T> input, Function<T, U> mapper) {
|
public static <T, U> List<U> mapList(Collection<T> input, Function<T, U> mapper) {
|
||||||
//todo: optimize hits mapping
|
var result = new ArrayList<U>(input.size());
|
||||||
return input.stream().map(mapper).toList();
|
input.forEach(t -> result.add(mapper.apply(t)));
|
||||||
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
private static class FakeBytesRefBuilder extends BytesRefBuilder {
|
private static class FakeBytesRefBuilder extends BytesRefBuilder {
|
||||||
|
@ -3,6 +3,7 @@ package it.cavallium.dbengine.database.disk;
|
|||||||
import static it.cavallium.dbengine.database.LLUtils.ALLOW_STATIC_OPTIONS;
|
import static it.cavallium.dbengine.database.LLUtils.ALLOW_STATIC_OPTIONS;
|
||||||
import static it.cavallium.dbengine.database.LLUtils.MARKER_ROCKSDB;
|
import static it.cavallium.dbengine.database.LLUtils.MARKER_ROCKSDB;
|
||||||
import static it.cavallium.dbengine.database.LLUtils.isBoundedRange;
|
import static it.cavallium.dbengine.database.LLUtils.isBoundedRange;
|
||||||
|
import static it.cavallium.dbengine.database.LLUtils.mapList;
|
||||||
import static it.cavallium.dbengine.database.LLUtils.toStringSafe;
|
import static it.cavallium.dbengine.database.LLUtils.toStringSafe;
|
||||||
import static it.cavallium.dbengine.database.disk.UpdateAtomicResultMode.DELTA;
|
import static it.cavallium.dbengine.database.disk.UpdateAtomicResultMode.DELTA;
|
||||||
import static it.cavallium.dbengine.utils.StreamUtils.LUCENE_SCHEDULER;
|
import static it.cavallium.dbengine.utils.StreamUtils.LUCENE_SCHEDULER;
|
||||||
@ -542,7 +543,7 @@ public class LLLocalDictionary implements LLDictionary {
|
|||||||
{
|
{
|
||||||
var readOptions = generateReadOptionsOrStatic(null);
|
var readOptions = generateReadOptionsOrStatic(null);
|
||||||
try {
|
try {
|
||||||
var inputs = db.multiGetAsList(readOptions, Lists.transform(keyBufsWindow, Buf::asArray));
|
var inputs = db.multiGetAsList(readOptions, mapList(keyBufsWindow, Buf::asArray));
|
||||||
mappedInputs = new ArrayList<>(inputs.size());
|
mappedInputs = new ArrayList<>(inputs.size());
|
||||||
for (int i = 0; i < inputs.size(); i++) {
|
for (int i = 0; i < inputs.size(); i++) {
|
||||||
var val = inputs.get(i);
|
var val = inputs.get(i);
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
package it.cavallium.dbengine.database.disk;
|
package it.cavallium.dbengine.database.disk;
|
||||||
|
|
||||||
import static it.cavallium.dbengine.database.LLUtils.MARKER_ROCKSDB;
|
import static it.cavallium.dbengine.database.LLUtils.MARKER_ROCKSDB;
|
||||||
|
import static it.cavallium.dbengine.database.LLUtils.mapList;
|
||||||
import static it.cavallium.dbengine.utils.StreamUtils.collect;
|
import static it.cavallium.dbengine.utils.StreamUtils.collect;
|
||||||
import static it.cavallium.dbengine.utils.StreamUtils.iterating;
|
import static it.cavallium.dbengine.utils.StreamUtils.iterating;
|
||||||
import static java.lang.Boolean.parseBoolean;
|
import static java.lang.Boolean.parseBoolean;
|
||||||
@ -276,11 +277,7 @@ public class LLLocalKeyValueDatabase extends Backuppable implements LLKeyValueDa
|
|||||||
columnFamilyOptions.setBottommostCompressionType(lastLevelOptions.compressionType);
|
columnFamilyOptions.setBottommostCompressionType(lastLevelOptions.compressionType);
|
||||||
columnFamilyOptions.setBottommostCompressionOptions(lastLevelOptions.compressionOptions);
|
columnFamilyOptions.setBottommostCompressionOptions(lastLevelOptions.compressionOptions);
|
||||||
|
|
||||||
columnFamilyOptions.setCompressionPerLevel(columnOptions
|
columnFamilyOptions.setCompressionPerLevel(mapList(columnOptions.levels(), v -> v.compression().getType()));
|
||||||
.levels()
|
|
||||||
.stream()
|
|
||||||
.map(v -> v.compression().getType())
|
|
||||||
.toList());
|
|
||||||
} else {
|
} else {
|
||||||
columnFamilyOptions.setNumLevels(7);
|
columnFamilyOptions.setNumLevels(7);
|
||||||
List<CompressionType> compressionTypes = new ArrayList<>(7);
|
List<CompressionType> compressionTypes = new ArrayList<>(7);
|
||||||
@ -932,10 +929,9 @@ public class LLLocalKeyValueDatabase extends Backuppable implements LLKeyValueDa
|
|||||||
|
|
||||||
requireNonNull(databasesDirPath);
|
requireNonNull(databasesDirPath);
|
||||||
requireNonNull(path.getFileName());
|
requireNonNull(path.getFileName());
|
||||||
List<DbPath> paths = convertPaths(databasesDirPath, path.getFileName(), databaseOptions.volumes())
|
List<DbPath> paths = mapList(convertPaths(databasesDirPath, path.getFileName(), databaseOptions.volumes()),
|
||||||
.stream()
|
p -> new DbPath(p.path, p.targetSize)
|
||||||
.map(p -> new DbPath(p.path, p.targetSize))
|
);
|
||||||
.toList();
|
|
||||||
options.setDbPaths(paths);
|
options.setDbPaths(paths);
|
||||||
options.setMaxOpenFiles(databaseOptions.maxOpenFiles().orElse(-1));
|
options.setMaxOpenFiles(databaseOptions.maxOpenFiles().orElse(-1));
|
||||||
if (databaseOptions.spinning()) {
|
if (databaseOptions.spinning()) {
|
||||||
|
@ -1,5 +1,7 @@
|
|||||||
package it.cavallium.dbengine.lucene.collector;
|
package it.cavallium.dbengine.lucene.collector;
|
||||||
|
|
||||||
|
import static it.cavallium.dbengine.database.LLUtils.mapList;
|
||||||
|
|
||||||
import it.cavallium.dbengine.lucene.IntSmear;
|
import it.cavallium.dbengine.lucene.IntSmear;
|
||||||
import it.unimi.dsi.fastutil.ints.IntHash;
|
import it.unimi.dsi.fastutil.ints.IntHash;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
@ -31,10 +33,9 @@ public class FastFacetsCollectorManager implements CollectorManager<FacetsCollec
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public FacetsCollector reduce(Collection<FacetsCollector> collectors) throws IOException {
|
public FacetsCollector reduce(Collection<FacetsCollector> collectors) throws IOException {
|
||||||
return FacetsCollector.wrap(facetsCollectorManager.reduce(collectors
|
return FacetsCollector.wrap(facetsCollectorManager.reduce(mapList(collectors,
|
||||||
.stream()
|
facetsCollector -> facetsCollector.getLuceneFacetsCollector()
|
||||||
.map(facetsCollector -> facetsCollector.getLuceneFacetsCollector())
|
)));
|
||||||
.toList()));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private static class FastFacetsCollector implements FacetsCollector {
|
private static class FastFacetsCollector implements FacetsCollector {
|
||||||
|
@ -1,5 +1,7 @@
|
|||||||
package it.cavallium.dbengine.lucene.searcher;
|
package it.cavallium.dbengine.lucene.searcher;
|
||||||
|
|
||||||
|
import static it.cavallium.dbengine.database.LLUtils.mapList;
|
||||||
|
|
||||||
import it.cavallium.dbengine.client.query.current.data.TotalHitsCount;
|
import it.cavallium.dbengine.client.query.current.data.TotalHitsCount;
|
||||||
import it.cavallium.dbengine.database.LLKeyScore;
|
import it.cavallium.dbengine.database.LLKeyScore;
|
||||||
import it.cavallium.dbengine.database.LLUtils;
|
import it.cavallium.dbengine.database.LLUtils;
|
||||||
@ -39,16 +41,9 @@ public class CountMultiSearcher implements MultiSearcher {
|
|||||||
"Scored queries are not supported by SimpleUnsortedUnscoredLuceneMultiSearcher");
|
"Scored queries are not supported by SimpleUnsortedUnscoredLuceneMultiSearcher");
|
||||||
}
|
}
|
||||||
|
|
||||||
var results = indexSearchers
|
var results = mapList(indexSearchers.llShards(),
|
||||||
.llShards()
|
searcher -> this.collect(searcher, queryParams, keyFieldName, transformer, f -> filterer.apply(f).limit(0))
|
||||||
.stream()
|
);
|
||||||
.map(searcher -> this.collect(searcher,
|
|
||||||
queryParams,
|
|
||||||
keyFieldName,
|
|
||||||
transformer,
|
|
||||||
f -> filterer.apply(f).limit(0)
|
|
||||||
))
|
|
||||||
.toList();
|
|
||||||
boolean exactTotalHitsCount = true;
|
boolean exactTotalHitsCount = true;
|
||||||
long totalHitsCountValue = 0;
|
long totalHitsCountValue = 0;
|
||||||
for (LuceneSearchResult result : results) {
|
for (LuceneSearchResult result : results) {
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
package it.cavallium.dbengine.lucene.searcher;
|
package it.cavallium.dbengine.lucene.searcher;
|
||||||
|
|
||||||
|
import static it.cavallium.dbengine.database.LLUtils.mapList;
|
||||||
import static it.cavallium.dbengine.utils.StreamUtils.toList;
|
import static it.cavallium.dbengine.utils.StreamUtils.toList;
|
||||||
import static java.util.Objects.requireNonNull;
|
import static java.util.Objects.requireNonNull;
|
||||||
|
|
||||||
@ -64,7 +65,7 @@ public class StandardSearcher implements MultiSearcher {
|
|||||||
sharedManager = TopScoreDocCollector.createSharedManager(queryParams.limitInt(), null, totalHitsThreshold);
|
sharedManager = TopScoreDocCollector.createSharedManager(queryParams.limitInt(), null, totalHitsThreshold);
|
||||||
}
|
}
|
||||||
;
|
;
|
||||||
var collectors = indexSearchers.stream().map(shard -> {
|
var collectors = mapList(indexSearchers, shard -> {
|
||||||
try {
|
try {
|
||||||
TopDocsCollector<?> collector;
|
TopDocsCollector<?> collector;
|
||||||
collector = sharedManager.newCollector();
|
collector = sharedManager.newCollector();
|
||||||
@ -77,7 +78,7 @@ public class StandardSearcher implements MultiSearcher {
|
|||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
throw new DBException(e);
|
throw new DBException(e);
|
||||||
}
|
}
|
||||||
}).toList();
|
});
|
||||||
|
|
||||||
try {
|
try {
|
||||||
if (collectors.size() <= 1) {
|
if (collectors.size() <= 1) {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user