Change filter implementation

main
Ankit Gupta 11 years ago
parent cea2be20b6
commit 5e797cf0dd
  1. 2
      java/Makefile
  2. 4
      java/RocksDBSample.java
  3. 50
      java/org/rocksdb/Filter.java
  4. 20
      java/org/rocksdb/Options.java
  5. 39
      java/rocksjni/filter.cc
  6. 18
      java/rocksjni/options.cc
  7. 34
      java/rocksjni/portal.h

@ -1,4 +1,4 @@
NATIVE_JAVA_CLASSES = org.rocksdb.RocksDB org.rocksdb.Options org.rocksdb.WriteBatch org.rocksdb.WriteBatchInternal org.rocksdb.WriteBatchTest org.rocksdb.WriteOptions org.rocksdb.BackupableDB org.rocksdb.BackupableDBOptions org.rocksdb.Statistics org.rocksdb.Iterator org.rocksdb.VectorMemTableConfig org.rocksdb.SkipListMemTableConfig org.rocksdb.HashLinkedListMemTableConfig org.rocksdb.HashSkipListMemTableConfig org.rocksdb.PlainTableConfig org.rocksdb.ReadOptions NATIVE_JAVA_CLASSES = org.rocksdb.RocksDB org.rocksdb.Options org.rocksdb.WriteBatch org.rocksdb.WriteBatchInternal org.rocksdb.WriteBatchTest org.rocksdb.WriteOptions org.rocksdb.BackupableDB org.rocksdb.BackupableDBOptions org.rocksdb.Statistics org.rocksdb.Iterator org.rocksdb.VectorMemTableConfig org.rocksdb.SkipListMemTableConfig org.rocksdb.HashLinkedListMemTableConfig org.rocksdb.HashSkipListMemTableConfig org.rocksdb.PlainTableConfig org.rocksdb.ReadOptions org.rocksdb.Filter
NATIVE_INCLUDE = ./include NATIVE_INCLUDE = ./include
ROCKSDB_JAR = rocksdbjni.jar ROCKSDB_JAR = rocksdbjni.jar

@ -32,6 +32,7 @@ public class RocksDBSample {
assert(db == null); assert(db == null);
} }
Filter filter = new Filter(10);
options.setCreateIfMissing(true) options.setCreateIfMissing(true)
.createStatistics() .createStatistics()
.setWriteBufferSize(8 * SizeUnit.KB) .setWriteBufferSize(8 * SizeUnit.KB)
@ -39,7 +40,7 @@ public class RocksDBSample {
.setDisableSeekCompaction(true) .setDisableSeekCompaction(true)
.setBlockSize(64 * SizeUnit.KB) .setBlockSize(64 * SizeUnit.KB)
.setMaxBackgroundCompactions(10) .setMaxBackgroundCompactions(10)
.createBloomFilter(10); .setFilter(filter);
Statistics stats = options.statisticsPtr(); Statistics stats = options.statisticsPtr();
assert(options.createIfMissing() == true); assert(options.createIfMissing() == true);
@ -225,5 +226,6 @@ public class RocksDBSample {
// be sure to dispose c++ pointers // be sure to dispose c++ pointers
options.dispose(); options.dispose();
readOptions.dispose(); readOptions.dispose();
filter.dispose();
} }
} }

@ -0,0 +1,50 @@
// Copyright (c) 2014, Facebook, Inc. All rights reserved.
// This source code is licensed under the BSD-style license found in the
// LICENSE file in the root directory of this source tree. An additional grant
// of patent rights can be found in the PATENTS file in the same directory.
package org.rocksdb;
/**
* Filters are stored in rocksdb and are consulted automatically
* by rocksdb to decide whether or not to read some
* information from disk. In many cases, a filter can cut down the
* number of disk seeks form a handful to a single disk seek per
* DB::Get() call.
*
* This function a new filter policy that uses a bloom filter
* with approximately the specified number of bits per key.
* A good value for bitsPerKey is 10, which yields a filter
* with ~ 1% false positive rate.
*/
public class Filter {
private long nativeHandle_;
public Filter(int bitsPerKey) {
newFilter(bitsPerKey);
}
public long getNativeHandle() {
return nativeHandle_;
}
/**
* Deletes underlying C++ filter pointer.
*/
public synchronized void dispose() {
if(nativeHandle_ != 0) {
dispose0(nativeHandle_);
}
}
@Override protected void finalize() {
dispose();
}
private boolean isInitialized() {
return (nativeHandle_ != 0);
}
private native void newFilter(int bitsPerKey);
private native void dispose0(long handle);
}

@ -145,24 +145,14 @@ public class Options {
} }
/** /**
* Filters are stored in rocksdb and are consulted automatically * Use the specified filter policy to reduce disk reads.
* by rocksdb to decide whether or not to read some * @param Filter policy java instance.
* information from disk. In many cases, a filter can cut down the
* number of disk seeks form a handful to a single disk seek per
* DB::Get() call.
*
* This function a new filter policy that uses a bloom filter
* with approximately the specified number of bits per key.
* A good value for bitsPerKey is 10, which yields a filter
* with ~ 1% false positive rate.
*
* @param Bits per key for bloom filter.
* @return the instance of the current Options. * @return the instance of the current Options.
* @see RocksDB.open() * @see RocksDB.open()
*/ */
public Options createBloomFilter(int bitsPerKey) { public Options setFilter(Filter filter) {
assert(isInitialized()); assert(isInitialized());
createBloomFilter0(nativeHandle_, bitsPerKey); setFilter0(nativeHandle_, filter.getNativeHandle());
return this; return this;
} }
@ -1260,7 +1250,7 @@ public class Options {
private native void useFixedLengthPrefixExtractor( private native void useFixedLengthPrefixExtractor(
long handle, int prefixLength); long handle, int prefixLength);
private native void createBloomFilter0(long handle, int bitsPerKey); private native void setFilter0(long optHandle, long fpHandle);
long nativeHandle_; long nativeHandle_;
long cacheSize_; long cacheSize_;

@ -0,0 +1,39 @@
// Copyright (c) 2014, Facebook, Inc. All rights reserved.
// This source code is licensed under the BSD-style license found in the
// LICENSE file in the root directory of this source tree. An additional grant
// of patent rights can be found in the PATENTS file in the same directory.
//
// This file implements the "bridge" between Java and C++ for rocksdb::Filter.
#include <stdio.h>
#include <stdlib.h>
#include <jni.h>
#include <string>
#include "include/org_rocksdb_Filter.h"
#include "rocksjni/portal.h"
#include "rocksdb/filter_policy.h"
/*
* Class: org_rocksdb_Filter
* Method: newFilter
* Signature: (I)V
*/
void Java_org_rocksdb_Filter_newFilter(
JNIEnv* env, jobject jobj, jint bits_per_key) {
const rocksdb::FilterPolicy* fp = rocksdb::NewBloomFilterPolicy(bits_per_key);
rocksdb::FilterJni::setHandle(env, jobj, fp);
}
/*
* Class: org_rocksdb_Filter
* Method: dispose0
* Signature: (J)V
*/
void Java_org_rocksdb_Filter_dispose0(
JNIEnv* env, jobject jobj, jlong handle) {
auto fp = reinterpret_cast<rocksdb::FilterPolicy*>(handle);
delete fp;
rocksdb::FilterJni::setHandle(env, jobj, nullptr);
}

@ -122,19 +122,13 @@ jlong Java_org_rocksdb_Options_statisticsPtr(
/* /*
* Class: org_rocksdb_Options * Class: org_rocksdb_Options
* Method: createBloomFilter0 * Method: setFilter0
* Signature: (JI)V * Signature: (JJ)V
*/ */
void Java_org_rocksdb_Options_createBloomFilter0( void Java_org_rocksdb_Options_setFilter0(
JNIEnv* env, jobject jobj, jlong jhandle, jint jbits_per_key) { JNIEnv* env, jobject jobj, jlong jopt_handle, jlong jfp_handle) {
rocksdb::Options* opt = reinterpret_cast<rocksdb::Options*>(jhandle); reinterpret_cast<rocksdb::Options*>(jopt_handle)->filter_policy =
reinterpret_cast<rocksdb::FilterPolicy*>(jfp_handle);
// Delete previously allocated pointer
if(opt->filter_policy) {
delete opt->filter_policy;
}
opt->filter_policy = rocksdb::NewBloomFilterPolicy(jbits_per_key);
} }
/* /*

@ -12,6 +12,7 @@
#include <jni.h> #include <jni.h>
#include "rocksdb/db.h" #include "rocksdb/db.h"
#include "rocksdb/filter_policy.h"
#include "utilities/backupable_db.h" #include "utilities/backupable_db.h"
namespace rocksdb { namespace rocksdb {
@ -281,5 +282,38 @@ class IteratorJni {
reinterpret_cast<jlong>(op)); reinterpret_cast<jlong>(op));
} }
}; };
class FilterJni {
public:
// Get the java class id of org.rocksdb.Filter.
static jclass getJClass(JNIEnv* env) {
static jclass jclazz = env->FindClass("org/rocksdb/Filter");
assert(jclazz != nullptr);
return jclazz;
}
// Get the field id of the member variable of org.rocksdb.Filter
// that stores the pointer to rocksdb::Iterator.
static jfieldID getHandleFieldID(JNIEnv* env) {
static jfieldID fid = env->GetFieldID(
getJClass(env), "nativeHandle_", "J");
assert(fid != nullptr);
return fid;
}
// Get the pointer to rocksdb::Filter.
static rocksdb::FilterPolicy* getHandle(JNIEnv* env, jobject jobj) {
return reinterpret_cast<rocksdb::FilterPolicy*>(
env->GetLongField(jobj, getHandleFieldID(env)));
}
// Pass the rocksdb::Filter pointer to the java side.
static void setHandle(
JNIEnv* env, jobject jobj, const rocksdb::FilterPolicy* op) {
env->SetLongField(
jobj, getHandleFieldID(env),
reinterpret_cast<jlong>(op));
}
};
} // namespace rocksdb } // namespace rocksdb
#endif // JAVA_ROCKSJNI_PORTAL_H_ #endif // JAVA_ROCKSJNI_PORTAL_H_

Loading…
Cancel
Save