All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.rocksdb.Logger Maven / Gradle / Ivy

Go to download

RocksDB fat jar that contains .so files for linux32 and linux64 (glibc and musl-libc), jnilib files for Mac OSX, and a .dll for Windows x64.

There is a newer version: 9.7.3
Show newest version
// Copyright (c) 2011-present, Facebook, Inc.  All rights reserved.
//  This source code is licensed under both the GPLv2 (found in the
//  COPYING file in the root directory) and Apache 2.0 License
//  (found in the LICENSE.Apache file in the root directory).

package org.rocksdb;

/**
 * 

This class provides a custom logger functionality * in Java which wraps {@code RocksDB} logging facilities. *

* *

Using this class RocksDB can log with common * Java logging APIs like Log4j or Slf4j without keeping * database logs in the filesystem.

* * Performance *

There are certain performance penalties using a Java * {@code Logger} implementation within production code. *

* *

* A log level can be set using {@link org.rocksdb.Options} or * {@link Logger#setInfoLogLevel(InfoLogLevel)}. The set log level * influences the underlying native code. Each log message is * checked against the set log level and if the log level is more * verbose as the set log level, native allocations will be made * and data structures are allocated. *

* *

Every log message which will be emitted by native code will * trigger expensive native to Java transitions. So the preferred * setting for production use is either * {@link org.rocksdb.InfoLogLevel#ERROR_LEVEL} or * {@link org.rocksdb.InfoLogLevel#FATAL_LEVEL}. *

*/ public abstract class Logger extends RocksCallbackObject implements LoggerInterface { /** *

AbstractLogger constructor.

* *

Important: the log level set within * the {@link org.rocksdb.Options} instance will be used as * maximum log level of RocksDB.

* * @param options {@link org.rocksdb.Options} instance. * * @deprecated Use {@link Logger#Logger(InfoLogLevel)} instead, e.g. {@code new * Logger(options.infoLogLevel())}. */ @Deprecated public Logger(final Options options) { this(options.infoLogLevel()); } /** *

AbstractLogger constructor.

* *

Important: the log level set within * the {@link org.rocksdb.DBOptions} instance will be used * as maximum log level of RocksDB.

* * @param dboptions {@link org.rocksdb.DBOptions} instance. * * @deprecated Use {@link Logger#Logger(InfoLogLevel)} instead, e.g. {@code new * Logger(dbOptions.infoLogLevel())}. */ @Deprecated public Logger(final DBOptions dboptions) { this(dboptions.infoLogLevel()); } /** *

AbstractLogger constructor.

* * @param logLevel the log level. */ public Logger(final InfoLogLevel logLevel) { super(logLevel.getValue()); } @Override protected long initializeNative(final long... nativeParameterHandles) { if (nativeParameterHandles.length == 1) { return newLogger(nativeParameterHandles[0]); } else { throw new IllegalArgumentException(); } } @Override public void setInfoLogLevel(final InfoLogLevel logLevel) { setInfoLogLevel(nativeHandle_, logLevel.getValue()); } @Override public InfoLogLevel infoLogLevel() { return InfoLogLevel.getInfoLogLevel( infoLogLevel(nativeHandle_)); } @Override public long getNativeHandle() { return nativeHandle_; } @Override public final LoggerType getLoggerType() { return LoggerType.JAVA_IMPLEMENTATION; } protected abstract void log(final InfoLogLevel logLevel, final String logMsg); protected native long newLogger(final long logLevel); protected native void setInfoLogLevel(final long handle, final byte logLevel); protected native byte infoLogLevel(final long handle); /** * We override {@link RocksCallbackObject#disposeInternal()} * as disposing of a rocksdb::LoggerJniCallback requires * a slightly different approach as it is a std::shared_ptr. */ @Override protected void disposeInternal() { disposeInternal(nativeHandle_); } private native void disposeInternal(final long handle); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy