WriteBufferManager JNI fixes (#4579)

Summary:
1. `WriteBufferManager` should have a reference alive in Java side through `Options`/`DBOptions` otherwise, if it's GC'ed at java side, native side can seg fault.
2. native method `setWriteBufferManager()` in `DBOptions.java` doesn't have it's jni method invocation in rocksdbjni which is added in this PR
3. `DBOptionsTest.java` is referencing object of `Options`. Instead it should be testing against `DBOptions`. Seems like a copy paste error.
4. Add a getter for WriteBufferManager.
Pull Request resolved: https://github.com/facebook/rocksdb/pull/4579

Differential Revision: D10561150

Pulled By: sagar0

fbshipit-source-id: 139a15c7f051a9f77b4200215b88267b48fbc487
main
Jigar Bhati 6 years ago committed by Facebook Github Bot
parent 8c78348c77
commit 6ecd26af27
  1. 14
      java/rocksjni/options.cc
  2. 9
      java/src/main/java/org/rocksdb/DBOptions.java
  3. 9
      java/src/main/java/org/rocksdb/DBOptionsInterface.java
  4. 9
      java/src/main/java/org/rocksdb/Options.java
  5. 6
      java/src/test/java/org/rocksdb/DBOptionsTest.java
  6. 2
      java/src/test/java/org/rocksdb/OptionsTest.java

@ -5532,6 +5532,20 @@ void Java_org_rocksdb_DBOptions_setDbWriteBufferSize(
opt->db_write_buffer_size = static_cast<size_t>(jdb_write_buffer_size); opt->db_write_buffer_size = static_cast<size_t>(jdb_write_buffer_size);
} }
/*
* Class: org_rocksdb_DBOptions
* Method: setWriteBufferManager
* Signature: (JJ)V
*/
void Java_org_rocksdb_DBOptions_setWriteBufferManager(JNIEnv* /*env*/, jobject /*jobj*/,
jlong jdb_options_handle,
jlong jwrite_buffer_manager_handle) {
auto* write_buffer_manager =
reinterpret_cast<std::shared_ptr<rocksdb::WriteBufferManager> *>(jwrite_buffer_manager_handle);
reinterpret_cast<rocksdb::DBOptions*>(jdb_options_handle)->write_buffer_manager =
*write_buffer_manager;
}
/* /*
* Class: org_rocksdb_DBOptions * Class: org_rocksdb_DBOptions
* Method: dbWriteBufferSize * Method: dbWriteBufferSize

@ -46,6 +46,7 @@ public class DBOptions
this.numShardBits_ = other.numShardBits_; this.numShardBits_ = other.numShardBits_;
this.rateLimiter_ = other.rateLimiter_; this.rateLimiter_ = other.rateLimiter_;
this.rowCache_ = other.rowCache_; this.rowCache_ = other.rowCache_;
this.writeBufferManager_ = other.writeBufferManager_;
} }
/** /**
@ -671,10 +672,17 @@ public class DBOptions
public DBOptions setWriteBufferManager(final WriteBufferManager writeBufferManager) { public DBOptions setWriteBufferManager(final WriteBufferManager writeBufferManager) {
assert(isOwningHandle()); assert(isOwningHandle());
setWriteBufferManager(nativeHandle_, writeBufferManager.nativeHandle_); setWriteBufferManager(nativeHandle_, writeBufferManager.nativeHandle_);
this.writeBufferManager_ = writeBufferManager;
return this; return this;
} }
@Override @Override
public WriteBufferManager writeBufferManager() {
assert(isOwningHandle());
return this.writeBufferManager_;
}
@Override
public long dbWriteBufferSize() { public long dbWriteBufferSize() {
assert(isOwningHandle()); assert(isOwningHandle());
return dbWriteBufferSize(nativeHandle_); return dbWriteBufferSize(nativeHandle_);
@ -1167,4 +1175,5 @@ public class DBOptions
private int numShardBits_; private int numShardBits_;
private RateLimiter rateLimiter_; private RateLimiter rateLimiter_;
private Cache rowCache_; private Cache rowCache_;
private WriteBufferManager writeBufferManager_;
} }

@ -1004,6 +1004,15 @@ public interface DBOptionsInterface<T extends DBOptionsInterface> {
*/ */
T setWriteBufferManager(final WriteBufferManager writeBufferManager); T setWriteBufferManager(final WriteBufferManager writeBufferManager);
/**
* Reference to {@link WriteBufferManager} used by it. <br>
*
* Default: null (Disabled)
*
* @return a reference to WriteBufferManager
*/
WriteBufferManager writeBufferManager();
/** /**
* Amount of data to build up in memtables across all column * Amount of data to build up in memtables across all column
* families before writing to disk. * families before writing to disk.

@ -70,6 +70,7 @@ public class Options extends RocksObject
this.compactionOptionsFIFO_ = other.compactionOptionsFIFO_; this.compactionOptionsFIFO_ = other.compactionOptionsFIFO_;
this.compressionOptions_ = other.compressionOptions_; this.compressionOptions_ = other.compressionOptions_;
this.rowCache_ = other.rowCache_; this.rowCache_ = other.rowCache_;
this.writeBufferManager_ = other.writeBufferManager_;
} }
@Override @Override
@ -727,10 +728,17 @@ public class Options extends RocksObject
public Options setWriteBufferManager(final WriteBufferManager writeBufferManager) { public Options setWriteBufferManager(final WriteBufferManager writeBufferManager) {
assert(isOwningHandle()); assert(isOwningHandle());
setWriteBufferManager(nativeHandle_, writeBufferManager.nativeHandle_); setWriteBufferManager(nativeHandle_, writeBufferManager.nativeHandle_);
this.writeBufferManager_ = writeBufferManager;
return this; return this;
} }
@Override @Override
public WriteBufferManager writeBufferManager() {
assert(isOwningHandle());
return this.writeBufferManager_;
}
@Override
public long dbWriteBufferSize() { public long dbWriteBufferSize() {
assert(isOwningHandle()); assert(isOwningHandle());
return dbWriteBufferSize(nativeHandle_); return dbWriteBufferSize(nativeHandle_);
@ -1918,4 +1926,5 @@ public class Options extends RocksObject
private CompactionOptionsFIFO compactionOptionsFIFO_; private CompactionOptionsFIFO compactionOptionsFIFO_;
private CompressionOptions compressionOptions_; private CompressionOptions compressionOptions_;
private Cache rowCache_; private Cache rowCache_;
private WriteBufferManager writeBufferManager_;
} }

@ -426,19 +426,21 @@ public class DBOptionsTest {
@Test @Test
public void setWriteBufferManager() throws RocksDBException { public void setWriteBufferManager() throws RocksDBException {
try (final Options opt = new Options(); try (final DBOptions opt = new DBOptions();
final Cache cache = new LRUCache(1 * 1024 * 1024); final Cache cache = new LRUCache(1 * 1024 * 1024);
final WriteBufferManager writeBufferManager = new WriteBufferManager(2000l, cache)) { final WriteBufferManager writeBufferManager = new WriteBufferManager(2000l, cache)) {
opt.setWriteBufferManager(writeBufferManager); opt.setWriteBufferManager(writeBufferManager);
assertThat(opt.writeBufferManager()).isEqualTo(writeBufferManager);
} }
} }
@Test @Test
public void setWriteBufferManagerWithZeroBufferSize() throws RocksDBException { public void setWriteBufferManagerWithZeroBufferSize() throws RocksDBException {
try (final Options opt = new Options(); try (final DBOptions opt = new DBOptions();
final Cache cache = new LRUCache(1 * 1024 * 1024); final Cache cache = new LRUCache(1 * 1024 * 1024);
final WriteBufferManager writeBufferManager = new WriteBufferManager(0l, cache)) { final WriteBufferManager writeBufferManager = new WriteBufferManager(0l, cache)) {
opt.setWriteBufferManager(writeBufferManager); opt.setWriteBufferManager(writeBufferManager);
assertThat(opt.writeBufferManager()).isEqualTo(writeBufferManager);
} }
} }

@ -651,6 +651,7 @@ public class OptionsTest {
final Cache cache = new LRUCache(1 * 1024 * 1024); final Cache cache = new LRUCache(1 * 1024 * 1024);
final WriteBufferManager writeBufferManager = new WriteBufferManager(2000l, cache)) { final WriteBufferManager writeBufferManager = new WriteBufferManager(2000l, cache)) {
opt.setWriteBufferManager(writeBufferManager); opt.setWriteBufferManager(writeBufferManager);
assertThat(opt.writeBufferManager()).isEqualTo(writeBufferManager);
} }
} }
@ -660,6 +661,7 @@ public class OptionsTest {
final Cache cache = new LRUCache(1 * 1024 * 1024); final Cache cache = new LRUCache(1 * 1024 * 1024);
final WriteBufferManager writeBufferManager = new WriteBufferManager(0l, cache)) { final WriteBufferManager writeBufferManager = new WriteBufferManager(0l, cache)) {
opt.setWriteBufferManager(writeBufferManager); opt.setWriteBufferManager(writeBufferManager);
assertThat(opt.writeBufferManager()).isEqualTo(writeBufferManager);
} }
} }

Loading…
Cancel
Save