fork of https://github.com/oxigraph/rocksdb and https://github.com/facebook/rocksdb for nextgraph and oxigraph
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
90 lines
2.7 KiB
90 lines
2.7 KiB
// 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;
|
|
|
|
/**
|
|
* A subclass of RocksDB which supports backup-related operations.
|
|
*
|
|
* @see BackupableDBOptions
|
|
*/
|
|
public class BackupableDB extends RocksDB {
|
|
/**
|
|
* Open a BackupableDB under the specified path.
|
|
* Note that the backup path should be set properly in the
|
|
* input BackupableDBOptions.
|
|
*
|
|
* @param opt options for db.
|
|
* @param bopt backup related options.
|
|
* @param the db path for storing data. The path for storing
|
|
* backup should be specified in the BackupableDBOptions.
|
|
* @return reference to the opened BackupableDB.
|
|
*/
|
|
public static BackupableDB open(
|
|
Options opt, BackupableDBOptions bopt, String db_path)
|
|
throws RocksDBException {
|
|
|
|
RocksDB db = RocksDB.open(opt, db_path);
|
|
BackupableDB bdb = new BackupableDB();
|
|
bdb.open(db.nativeHandle_, bopt.nativeHandle_);
|
|
|
|
// Prevent the RocksDB object from attempting to delete
|
|
// the underly C++ DB object.
|
|
db.disOwnNativeHandle();
|
|
|
|
return bdb;
|
|
}
|
|
|
|
/**
|
|
* Captures the state of the database in the latest backup.
|
|
* Note that this function is not thread-safe.
|
|
*
|
|
* @param flushBeforeBackup if true, then all data will be flushed
|
|
* before creating backup.
|
|
*/
|
|
public void createNewBackup(boolean flushBeforeBackup) {
|
|
createNewBackup(nativeHandle_, flushBeforeBackup);
|
|
}
|
|
|
|
/**
|
|
* Deletes old backups, keeping latest numBackupsToKeep alive.
|
|
*
|
|
* @param numBackupsToKeep Number of latest backups to keep.
|
|
*/
|
|
public void purgeOldBackups(int numBackupsToKeep) {
|
|
purgeOldBackups(nativeHandle_, numBackupsToKeep);
|
|
}
|
|
|
|
|
|
/**
|
|
* Close the BackupableDB instance and release resource.
|
|
*
|
|
* Internally, BackupableDB owns the rocksdb::DB pointer to its
|
|
* associated RocksDB. The release of that RocksDB pointer is
|
|
* handled in the destructor of the c++ rocksdb::BackupableDB and
|
|
* should be transparent to Java developers.
|
|
*/
|
|
@Override public synchronized void close() {
|
|
if (isInitialized()) {
|
|
super.close();
|
|
}
|
|
}
|
|
|
|
/**
|
|
* A protected construction that will be used in the static factory
|
|
* method BackupableDB.open().
|
|
*/
|
|
protected BackupableDB() {
|
|
super();
|
|
}
|
|
|
|
@Override protected void finalize() {
|
|
close();
|
|
}
|
|
|
|
protected native void open(long rocksDBHandle, long backupDBOptionsHandle);
|
|
protected native void createNewBackup(long handle, boolean flag);
|
|
protected native void purgeOldBackups(long handle, int numBackupsToKeep);
|
|
}
|
|
|