Add histogramType for statistics

This commit is contained in:
Ankit Gupta 2014-04-16 21:38:33 -07:00
parent 144066a8ff
commit 320ae72e17
7 changed files with 60 additions and 14 deletions

View File

@ -420,7 +420,7 @@ ldb: tools/ldb.o $(LIBOBJECTS)
# --------------------------------------------------------------------------- # ---------------------------------------------------------------------------
# Jni stuff # Jni stuff
# --------------------------------------------------------------------------- # ---------------------------------------------------------------------------
JNI_NATIVE_SOURCES = ./java/rocksjni/rocksjni.cc ./java/rocksjni/options.cc ./java/rocksjni/write_batch.cc JNI_NATIVE_SOURCES = ./java/rocksjni/rocksjni.cc ./java/rocksjni/options.cc ./java/rocksjni/write_batch.cc ./java/rocksjni/statistics.cc
JAVA_INCLUDE = -I/usr/lib/jvm/java-openjdk/include/ -I/usr/lib/jvm/java-openjdk/include/linux JAVA_INCLUDE = -I/usr/lib/jvm/java-openjdk/include/ -I/usr/lib/jvm/java-openjdk/include/linux
ROCKSDBJNILIB = ./java/librocksdbjni.so ROCKSDBJNILIB = ./java/librocksdbjni.so

View File

@ -16,7 +16,7 @@ sample: java
javac -cp $(ROCKSDB_JAR) RocksDBSample.java javac -cp $(ROCKSDB_JAR) RocksDBSample.java
@rm -rf /tmp/rocksdbjni @rm -rf /tmp/rocksdbjni
@rm -rf /tmp/rocksdbjni_not_found @rm -rf /tmp/rocksdbjni_not_found
java -ea -Djava.library.path=.:../ -cp ".:./*" RocksDBSample /tmp/rocksdbjni java -ea -Djava.library.path=.:../ -cp ".:./*" -Xcheck:jni RocksDBSample /tmp/rocksdbjni
@rm -rf /tmp/rocksdbjni @rm -rf /tmp/rocksdbjni
@rm -rf /tmp/rocksdbjni_not_found @rm -rf /tmp/rocksdbjni_not_found

View File

@ -40,7 +40,7 @@ public class RocksDBSample {
.setDisableSeekCompaction(true) .setDisableSeekCompaction(true)
.setBlockSize(64 * SizeUnit.KB) .setBlockSize(64 * SizeUnit.KB)
.setMaxBackgroundCompactions(10); .setMaxBackgroundCompactions(10);
Statistics stats = new Statistics(options.statisticsPtr()); Statistics stats = options.statisticsPtr();
assert(options.createIfMissing() == true); assert(options.createIfMissing() == true);
assert(options.writeBufferSize() == 8 * SizeUnit.KB); assert(options.writeBufferSize() == 8 * SizeUnit.KB);
@ -124,16 +124,24 @@ public class RocksDBSample {
writeOpts.dispose(); writeOpts.dispose();
try { try {
for(TickerType statsType : TickerType.values()) { for (TickerType statsType : TickerType.values()) {
stats.getTickerCount(statsType); stats.getTickerCount(statsType);
} }
System.out.println("getTickerCount() passed."); System.out.println("getTickerCount() passed.");
} } catch (Exception e) {
catch(Exception e) {
System.out.println("Failed in call to getTickerCount()"); System.out.println("Failed in call to getTickerCount()");
assert(false); //Should never reach here. assert(false); //Should never reach here.
} }
try {
for (HistogramType histogramType : HistogramType.values()) {
HistogramData data = stats.geHistogramData(histogramType);
}
System.out.println("geHistogramData() passed.");
} catch (Exception e) {
System.out.println("Failed in call to geHistogramData()");
assert(false); //Should never reach here.
}
} catch (RocksDBException e) { } catch (RocksDBException e) {
System.err.println(e); System.err.println(e);
} }

View File

@ -220,13 +220,16 @@ public class Options {
* *
* @see createStatistics() * @see createStatistics()
*/ */
public long statisticsPtr() { public Statistics statisticsPtr() {
assert(isInitialized()); assert(isInitialized());
long statsPtr = statisticsPtr(nativeHandle_); long statsPtr = statisticsPtr(nativeHandle_);
assert(statsPtr != 0); if(statsPtr == 0) {
createStatistics();
statsPtr = statisticsPtr(nativeHandle_);
}
return statsPtr; return new Statistics(statsPtr);
} }
/** /**

View File

@ -11,7 +11,7 @@ package org.rocksdb;
*/ */
public class Statistics { public class Statistics {
private long statsHandle_; private final long statsHandle_;
public Statistics(long statsHandle) { public Statistics(long statsHandle) {
statsHandle_ = statsHandle; statsHandle_ = statsHandle;
@ -22,9 +22,16 @@ public class Statistics {
return getTickerCount0(tickerType.getValue(), statsHandle_); return getTickerCount0(tickerType.getValue(), statsHandle_);
} }
public HistogramData geHistogramData(HistogramType histogramType) {
assert(isInitialized());
HistogramData hist = geHistogramData0(histogramType.getValue(), statsHandle_);
return hist;
}
private boolean isInitialized() { private boolean isInitialized() {
return (statsHandle_ != 0); return (statsHandle_ != 0);
} }
private native long getTickerCount0(int ticker, long handle); private native long getTickerCount0(int tickerType, long handle);
private native HistogramData geHistogramData0(int histogramType, long handle);
} }

View File

@ -170,5 +170,15 @@ class WriteBatchJni {
reinterpret_cast<jlong>(wb)); reinterpret_cast<jlong>(wb));
} }
}; };
class HistogramDataJni {
public:
static jmethodID getConstructorMethodId(JNIEnv* env, jclass jclazz) {
static jmethodID mid = env->GetMethodID(
jclazz, "<init>", "(DDDDD)V");
assert(mid != nullptr);
return mid;
}
};
} // namespace rocksdb } // namespace rocksdb
#endif // JAVA_ROCKSJNI_PORTAL_H_ #endif // JAVA_ROCKSJNI_PORTAL_H_

View File

@ -13,6 +13,7 @@
#include "include/org_rocksdb_Statistics.h" #include "include/org_rocksdb_Statistics.h"
#include "rocksjni/portal.h" #include "rocksjni/portal.h"
#include "rocksdb/statistics.h" #include "rocksdb/statistics.h"
#include <iostream>
/* /*
* Class: org_rocksdb_Statistics * Class: org_rocksdb_Statistics
@ -20,9 +21,26 @@
* Signature: (IJ)J * Signature: (IJ)J
*/ */
jlong Java_org_rocksdb_Statistics_getTickerCount0( jlong Java_org_rocksdb_Statistics_getTickerCount0(
JNIEnv* env, jobject jobj, int ticker, jlong handle) { JNIEnv* env, jobject jobj, int tickerType, jlong handle) {
auto st = reinterpret_cast<rocksdb::Statistics*>(handle); auto st = reinterpret_cast<rocksdb::Statistics*>(handle);
assert(st != nullptr); assert(st != nullptr);
return st->getTickerCount(static_cast<rocksdb::Tickers>(ticker)); return st->getTickerCount(static_cast<rocksdb::Tickers>(tickerType));
}
jobject Java_org_rocksdb_Statistics_geHistogramData0(
JNIEnv* env, jobject jobj, int histogramType, jlong handle) {
auto st = reinterpret_cast<rocksdb::Statistics*>(handle);
assert(st != nullptr);
rocksdb::HistogramData data;
st->histogramData(static_cast<rocksdb::Histograms>(histogramType),
&data);
// Don't reuse class pointer
jclass jclazz = env->FindClass("org/rocksdb/HistogramData");
jmethodID mid = rocksdb::HistogramDataJni::getConstructorMethodId(
env, jclazz);
return env->NewObject(jclazz, mid, data.median, data.percentile95,
data.percentile99, data.average, data.standard_deviation);
} }