2014-05-13 22:20:58 -07:00
|
|
|
// 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;
|
|
|
|
|
2014-10-26 23:23:06 +01:00
|
|
|
import java.util.List;
|
|
|
|
|
2014-05-13 22:20:58 -07:00
|
|
|
/**
|
2014-11-16 14:36:22 +01:00
|
|
|
* <p>This class is used to access information about backups and
|
|
|
|
* restore from them.</p>
|
2014-05-18 22:40:48 -07:00
|
|
|
*
|
2014-11-16 14:36:22 +01:00
|
|
|
* <p>Note: {@code dispose()} must be called before this instance
|
|
|
|
* become out-of-scope to release the allocated
|
|
|
|
* memory in c++.</p>
|
2014-05-18 22:40:48 -07:00
|
|
|
*
|
2014-05-13 22:20:58 -07:00
|
|
|
*/
|
|
|
|
public class RestoreBackupableDB extends RocksObject {
|
2014-10-03 11:50:40 +02:00
|
|
|
/**
|
2014-11-16 14:36:22 +01:00
|
|
|
* <p>Construct new estoreBackupableDB instance.</p>
|
2014-10-03 11:50:40 +02:00
|
|
|
*
|
|
|
|
* @param options {@link org.rocksdb.BackupableDBOptions} instance
|
|
|
|
*/
|
2014-05-13 22:20:58 -07:00
|
|
|
public RestoreBackupableDB(BackupableDBOptions options) {
|
|
|
|
super();
|
2014-05-18 22:40:48 -07:00
|
|
|
nativeHandle_ = newRestoreBackupableDB(options.nativeHandle_);
|
2014-05-13 22:20:58 -07:00
|
|
|
}
|
2014-05-18 22:40:48 -07:00
|
|
|
|
2014-05-13 22:20:58 -07:00
|
|
|
/**
|
2014-11-16 14:36:22 +01:00
|
|
|
* <p>Restore from backup with backup_id.</p>
|
2014-05-18 22:40:48 -07:00
|
|
|
*
|
2014-11-16 14:36:22 +01:00
|
|
|
* <p><strong>Important</strong>: If options_.share_table_files == true
|
|
|
|
* and you restore DB from some backup that is not the latest, and you
|
|
|
|
* start creating new backups from the new DB, they will probably
|
|
|
|
* fail.</p>
|
|
|
|
*
|
|
|
|
* <p><strong>Example</strong>: Let's say you have backups 1, 2, 3, 4, 5
|
|
|
|
* and you restore 3. If you add new data to the DB and try creating a new
|
|
|
|
* backup now, the database will diverge from backups 4 and 5 and the new
|
|
|
|
* backup will fail. If you want to create new backup, you will first have
|
|
|
|
* to delete backups 4 and 5.</p>
|
2014-10-03 11:50:40 +02:00
|
|
|
*
|
|
|
|
* @param backupId id pointing to backup
|
|
|
|
* @param dbDir database directory to restore to
|
|
|
|
* @param walDir directory where wal files are located
|
2014-11-08 20:35:35 +01:00
|
|
|
* @param restoreOptions {@link org.rocksdb.RestoreOptions} instance.
|
|
|
|
*
|
|
|
|
* @throws RocksDBException thrown if error happens in underlying
|
|
|
|
* native library.
|
2014-05-13 22:20:58 -07:00
|
|
|
*/
|
|
|
|
public void restoreDBFromBackup(long backupId, String dbDir, String walDir,
|
|
|
|
RestoreOptions restoreOptions) throws RocksDBException {
|
2014-11-16 14:36:22 +01:00
|
|
|
assert(isInitialized());
|
2014-05-13 22:20:58 -07:00
|
|
|
restoreDBFromBackup0(nativeHandle_, backupId, dbDir, walDir,
|
|
|
|
restoreOptions.nativeHandle_);
|
|
|
|
}
|
2014-05-18 22:40:48 -07:00
|
|
|
|
2014-05-13 22:20:58 -07:00
|
|
|
/**
|
2014-11-16 14:36:22 +01:00
|
|
|
* <p>Restore from the latest backup.</p>
|
2014-10-03 11:50:40 +02:00
|
|
|
*
|
|
|
|
* @param dbDir database directory to restore to
|
|
|
|
* @param walDir directory where wal files are located
|
|
|
|
* @param restoreOptions {@link org.rocksdb.RestoreOptions} instance
|
2014-11-08 20:35:35 +01:00
|
|
|
*
|
|
|
|
* @throws RocksDBException thrown if error happens in underlying
|
|
|
|
* native library.
|
2014-05-13 22:20:58 -07:00
|
|
|
*/
|
|
|
|
public void restoreDBFromLatestBackup(String dbDir, String walDir,
|
|
|
|
RestoreOptions restoreOptions) throws RocksDBException {
|
2014-11-16 14:36:22 +01:00
|
|
|
assert(isInitialized());
|
2014-05-13 22:20:58 -07:00
|
|
|
restoreDBFromLatestBackup0(nativeHandle_, dbDir, walDir,
|
|
|
|
restoreOptions.nativeHandle_);
|
|
|
|
}
|
2014-05-18 22:40:48 -07:00
|
|
|
|
2014-05-13 22:20:58 -07:00
|
|
|
/**
|
2014-11-16 14:36:22 +01:00
|
|
|
* <p>Deletes old backups, keeping latest numBackupsToKeep alive.</p>
|
2014-05-18 22:40:48 -07:00
|
|
|
*
|
2014-10-03 11:50:40 +02:00
|
|
|
* @param numBackupsToKeep of latest backups to keep
|
2014-11-08 20:35:35 +01:00
|
|
|
*
|
|
|
|
* @throws RocksDBException thrown if error happens in underlying
|
|
|
|
* native library.
|
2014-05-13 22:20:58 -07:00
|
|
|
*/
|
|
|
|
public void purgeOldBackups(int numBackupsToKeep) throws RocksDBException {
|
2014-11-16 14:36:22 +01:00
|
|
|
assert(isInitialized());
|
2014-05-13 22:20:58 -07:00
|
|
|
purgeOldBackups0(nativeHandle_, numBackupsToKeep);
|
|
|
|
}
|
2014-05-18 22:40:48 -07:00
|
|
|
|
2014-05-13 22:20:58 -07:00
|
|
|
/**
|
2014-11-16 14:36:22 +01:00
|
|
|
* <p>Deletes a specific backup.</p>
|
2014-05-18 22:40:48 -07:00
|
|
|
*
|
2014-10-03 11:50:40 +02:00
|
|
|
* @param backupId of backup to delete.
|
2014-11-08 20:35:35 +01:00
|
|
|
*
|
|
|
|
* @throws RocksDBException thrown if error happens in underlying
|
|
|
|
* native library.
|
2014-05-13 22:20:58 -07:00
|
|
|
*/
|
2014-10-28 18:42:30 +01:00
|
|
|
public void deleteBackup(int backupId) throws RocksDBException {
|
2014-11-16 14:36:22 +01:00
|
|
|
assert(isInitialized());
|
2014-05-13 22:20:58 -07:00
|
|
|
deleteBackup0(nativeHandle_, backupId);
|
|
|
|
}
|
2014-05-18 22:40:48 -07:00
|
|
|
|
2014-10-26 23:23:06 +01:00
|
|
|
/**
|
2014-11-16 14:36:22 +01:00
|
|
|
* <p>Returns a list of {@link BackupInfo} instances, which describe
|
|
|
|
* already made backups.</p>
|
2014-10-26 23:23:06 +01:00
|
|
|
*
|
|
|
|
* @return List of {@link BackupInfo} instances.
|
|
|
|
*/
|
|
|
|
public List<BackupInfo> getBackupInfos() {
|
2014-11-16 14:36:22 +01:00
|
|
|
assert(isInitialized());
|
2014-10-26 23:23:06 +01:00
|
|
|
return getBackupInfo(nativeHandle_);
|
|
|
|
}
|
|
|
|
|
2014-11-15 23:42:03 +01:00
|
|
|
/**
|
|
|
|
* <p>Returns a list of corrupted backup ids. If there
|
|
|
|
* is no corrupted backup the method will return an
|
|
|
|
* empty list.</p>
|
|
|
|
*
|
2014-11-20 22:47:48 +01:00
|
|
|
* @return array of backup ids as int ids.
|
2014-11-15 23:42:03 +01:00
|
|
|
*/
|
2014-11-20 22:47:48 +01:00
|
|
|
public int[] getCorruptedBackups() {
|
2014-11-16 14:36:22 +01:00
|
|
|
assert(isInitialized());
|
2014-11-15 23:42:03 +01:00
|
|
|
return getCorruptedBackups(nativeHandle_);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* <p>Will delete all the files we don't need anymore. It will
|
|
|
|
* do the full scan of the files/ directory and delete all the
|
|
|
|
* files that are not referenced.</p>
|
|
|
|
*
|
|
|
|
* @throws RocksDBException thrown if error happens in underlying
|
|
|
|
* native library.
|
|
|
|
*/
|
|
|
|
public void garbageCollect() throws RocksDBException {
|
2014-11-16 14:36:22 +01:00
|
|
|
assert(isInitialized());
|
2014-11-15 23:42:03 +01:00
|
|
|
garbageCollect(nativeHandle_);
|
|
|
|
}
|
|
|
|
|
2014-05-13 22:20:58 -07:00
|
|
|
/**
|
2014-11-16 14:36:22 +01:00
|
|
|
* <p>Release the memory allocated for the current instance
|
|
|
|
* in the c++ side.</p>
|
2014-05-13 22:20:58 -07:00
|
|
|
*/
|
2014-06-05 13:34:38 +01:00
|
|
|
@Override public synchronized void disposeInternal() {
|
|
|
|
dispose(nativeHandle_);
|
2014-05-13 22:20:58 -07:00
|
|
|
}
|
2014-05-18 22:40:48 -07:00
|
|
|
|
|
|
|
private native long newRestoreBackupableDB(long options);
|
2014-05-13 22:20:58 -07:00
|
|
|
private native void restoreDBFromBackup0(long nativeHandle, long backupId,
|
2014-10-26 23:23:06 +01:00
|
|
|
String dbDir, String walDir, long restoreOptions)
|
|
|
|
throws RocksDBException;
|
2014-05-13 22:20:58 -07:00
|
|
|
private native void restoreDBFromLatestBackup0(long nativeHandle,
|
2014-10-26 23:23:06 +01:00
|
|
|
String dbDir, String walDir, long restoreOptions)
|
|
|
|
throws RocksDBException;
|
|
|
|
private native void purgeOldBackups0(long nativeHandle, int numBackupsToKeep)
|
|
|
|
throws RocksDBException;
|
2014-10-28 18:42:30 +01:00
|
|
|
private native void deleteBackup0(long nativeHandle, int backupId)
|
2014-10-26 23:23:06 +01:00
|
|
|
throws RocksDBException;
|
2014-11-15 23:42:03 +01:00
|
|
|
private native List<BackupInfo> getBackupInfo(long handle);
|
2014-11-20 22:47:48 +01:00
|
|
|
private native int[] getCorruptedBackups(long handle);
|
2014-11-15 23:42:03 +01:00
|
|
|
private native void garbageCollect(long handle)
|
|
|
|
throws RocksDBException;
|
2014-05-13 22:20:58 -07:00
|
|
|
private native void dispose(long nativeHandle);
|
2014-05-13 22:34:29 -07:00
|
|
|
}
|