Bugfix
This commit is contained in:
parent
04df5f4a36
commit
7588cd3219
@ -127,11 +127,15 @@ public class DatabaseMapDictionary<T, U> extends DatabaseMapDictionaryDeep<T, U,
|
||||
ByteBuf keySuffixBuf = serializeSuffix(keySuffix);
|
||||
ByteBuf keyBuf = toKey(keySuffixBuf.retain());
|
||||
ByteBuf valueBuf = serialize(value);
|
||||
return dictionary.put(keyBuf.retain(), valueBuf.retain(), LLDictionaryResultType.VOID).doFinally(s -> {
|
||||
keyBuf.release();
|
||||
keySuffixBuf.release();
|
||||
valueBuf.release();
|
||||
}).then();
|
||||
return dictionary
|
||||
.put(keyBuf.retain(), valueBuf.retain(), LLDictionaryResultType.VOID)
|
||||
.doOnNext(ReferenceCounted::release)
|
||||
.doFinally(s -> {
|
||||
keyBuf.release();
|
||||
keySuffixBuf.release();
|
||||
valueBuf.release();
|
||||
})
|
||||
.then();
|
||||
}
|
||||
|
||||
@Override
|
||||
@ -201,7 +205,10 @@ public class DatabaseMapDictionary<T, U> extends DatabaseMapDictionaryDeep<T, U,
|
||||
return Mono
|
||||
.using(
|
||||
() -> toKey(serializeSuffix(keySuffix)),
|
||||
keyBuf -> dictionary.remove(keyBuf.retain(), LLDictionaryResultType.VOID).then(),
|
||||
keyBuf -> dictionary
|
||||
.remove(keyBuf.retain(), LLDictionaryResultType.VOID)
|
||||
.doOnNext(ReferenceCounted::release)
|
||||
.then(),
|
||||
ReferenceCounted::release
|
||||
);
|
||||
}
|
||||
@ -335,6 +342,7 @@ public class DatabaseMapDictionary<T, U> extends DatabaseMapDictionaryDeep<T, U,
|
||||
} else if (range.isSingle()) {
|
||||
return dictionary
|
||||
.remove(range.getSingle().retain(), LLDictionaryResultType.VOID)
|
||||
.doOnNext(ReferenceCounted::release)
|
||||
.then();
|
||||
} else {
|
||||
return dictionary
|
||||
|
@ -537,6 +537,7 @@ public class DatabaseMapDictionaryDeep<T, U, US extends DatabaseStage<U>> implem
|
||||
return Mono
|
||||
.defer(() -> dictionary
|
||||
.remove(range.getSingle().retain(), LLDictionaryResultType.VOID)
|
||||
.doOnNext(ReferenceCounted::release)
|
||||
)
|
||||
.then();
|
||||
} else {
|
||||
|
@ -81,11 +81,19 @@ public class LLLocalDictionary implements LLDictionary {
|
||||
/**
|
||||
* Default: true. Use false to debug problems with write batches.
|
||||
*/
|
||||
static final boolean USE_WRITE_BATCHES_IN_SET_RANGE = false;
|
||||
static final boolean USE_WRITE_BATCHES_IN_PUT_MULTI = true;
|
||||
/**
|
||||
* Default: true. Use false to debug problems with write batches.
|
||||
*/
|
||||
static final boolean USE_WRITE_BATCHES_IN_SET_RANGE = true;
|
||||
/**
|
||||
* Default: true. Use false to debug problems with capped write batches.
|
||||
*/
|
||||
static final boolean USE_CAPPED_WRITE_BATCH_IN_SET_RANGE = true;
|
||||
/**
|
||||
* Default: true. Use false to debug problems with write batches deletes.
|
||||
*/
|
||||
static final boolean USE_WRITE_BATCH_IN_SET_RANGE_DELETE = false;
|
||||
static final boolean PARALLEL_EXACT_SIZE = true;
|
||||
|
||||
private static final int STRIPES = 512;
|
||||
@ -774,7 +782,7 @@ public class LLLocalDictionary implements LLDictionary {
|
||||
stamps = null;
|
||||
}
|
||||
try {
|
||||
if (USE_WRITE_BATCHES_IN_SET_RANGE) {
|
||||
if (USE_WRITE_BATCHES_IN_PUT_MULTI) {
|
||||
var batch = new CappedWriteBatch(db,
|
||||
CAPPED_WRITE_BATCH_CAP,
|
||||
RESERVED_WRITE_BATCH_SIZE,
|
||||
@ -1003,7 +1011,7 @@ public class LLLocalDictionary implements LLDictionary {
|
||||
if (USE_WINDOW_IN_SET_RANGE) {
|
||||
return Mono
|
||||
.<Void>fromCallable(() -> {
|
||||
if (!USE_WRITE_BATCHES_IN_SET_RANGE) {
|
||||
if (!USE_WRITE_BATCH_IN_SET_RANGE_DELETE || !USE_WRITE_BATCHES_IN_SET_RANGE) {
|
||||
var opts = new ReadOptions(EMPTY_READ_OPTIONS);
|
||||
ReleasableSlice minBound;
|
||||
if (range.hasMin()) {
|
||||
@ -1149,6 +1157,7 @@ public class LLLocalDictionary implements LLDictionary {
|
||||
)
|
||||
.then(entries
|
||||
.flatMap(entry -> this.put(entry.getKey(), entry.getValue(), LLDictionaryResultType.VOID))
|
||||
.doOnNext(ReferenceCounted::release)
|
||||
.then(Mono.<Void>empty())
|
||||
)
|
||||
.onErrorMap(cause -> new IOException("Failed to write range", cause))
|
||||
@ -1156,6 +1165,7 @@ public class LLLocalDictionary implements LLDictionary {
|
||||
}
|
||||
}
|
||||
|
||||
//todo: this is broken, check why
|
||||
private void deleteSmallRangeWriteBatch(CappedWriteBatch writeBatch, LLRange range)
|
||||
throws RocksDBException {
|
||||
try {
|
||||
@ -1181,7 +1191,8 @@ public class LLLocalDictionary implements LLDictionary {
|
||||
rocksIterator.seekToFirst();
|
||||
}
|
||||
while (rocksIterator.isValid()) {
|
||||
writeBatch.delete(cfh, LLUtils.readDirectNioBuffer(alloc, rocksIterator::key));
|
||||
var b = LLUtils.toArray(LLUtils.readDirectNioBuffer(alloc, rocksIterator::key));
|
||||
writeBatch.delete(cfh, b);
|
||||
rocksIterator.next();
|
||||
}
|
||||
} finally {
|
||||
|
Loading…
x
Reference in New Issue
Block a user