2018-02-07 22:45:41 +03:00
|
|
|
/*
|
|
|
|
* Copyright (c) 2016-present, 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.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
#pragma once
|
2019-05-15 22:15:49 +03:00
|
|
|
#include <folly/CppAttributes.h>
|
|
|
|
|
2018-02-07 22:45:41 +03:00
|
|
|
#include "eden/fs/rocksdb/RocksHandles.h"
|
|
|
|
#include "eden/fs/store/LocalStore.h"
|
2018-08-03 23:08:37 +03:00
|
|
|
#include "eden/fs/utils/UnboundedQueueExecutor.h"
|
2018-02-07 22:45:41 +03:00
|
|
|
|
|
|
|
namespace facebook {
|
|
|
|
namespace eden {
|
|
|
|
|
2019-03-13 05:25:54 +03:00
|
|
|
class FaultInjector;
|
2018-11-09 22:20:16 +03:00
|
|
|
|
2018-02-07 22:45:41 +03:00
|
|
|
/** An implementation of LocalStore that uses RocksDB for the underlying
|
|
|
|
* storage.
|
|
|
|
*/
|
|
|
|
class RocksDbLocalStore : public LocalStore {
|
|
|
|
public:
|
2019-03-13 05:25:54 +03:00
|
|
|
/**
|
|
|
|
* The given FaultInjector must be valid during the lifetime of this
|
|
|
|
* RocksDbLocalStore object.
|
|
|
|
*/
|
2019-05-15 22:15:49 +03:00
|
|
|
explicit RocksDbLocalStore(
|
|
|
|
AbsolutePathPiece pathToRocksDb,
|
|
|
|
FaultInjector* FOLLY_NONNULL faultInjector);
|
2018-02-07 22:45:41 +03:00
|
|
|
~RocksDbLocalStore();
|
|
|
|
void close() override;
|
2018-05-31 20:39:49 +03:00
|
|
|
void clearKeySpace(KeySpace keySpace) override;
|
2018-08-10 21:09:48 +03:00
|
|
|
void compactKeySpace(KeySpace keySpace) override;
|
2018-02-07 22:45:41 +03:00
|
|
|
StoreResult get(LocalStore::KeySpace keySpace, folly::ByteRange key)
|
|
|
|
const override;
|
2018-05-10 04:41:22 +03:00
|
|
|
FOLLY_NODISCARD folly::Future<StoreResult> getFuture(
|
|
|
|
KeySpace keySpace,
|
|
|
|
folly::ByteRange key) const override;
|
2018-05-25 23:47:54 +03:00
|
|
|
FOLLY_NODISCARD folly::Future<std::vector<StoreResult>> getBatch(
|
|
|
|
KeySpace keySpace,
|
|
|
|
const std::vector<folly::ByteRange>& keys) const override;
|
2018-02-07 22:45:41 +03:00
|
|
|
bool hasKey(LocalStore::KeySpace keySpace, folly::ByteRange key)
|
|
|
|
const override;
|
|
|
|
void put(
|
|
|
|
LocalStore::KeySpace keySpace,
|
|
|
|
folly::ByteRange key,
|
|
|
|
folly::ByteRange value) override;
|
|
|
|
std::unique_ptr<WriteBatch> beginWrite(size_t bufSize = 0) override;
|
|
|
|
|
2019-04-25 05:59:48 +03:00
|
|
|
// Call RocksDB's RepairDB() function on the DB at the specified location
|
|
|
|
static void repairDB(AbsolutePathPiece path);
|
|
|
|
|
2019-05-15 22:15:49 +03:00
|
|
|
// Get the approximate number of bytes stored on disk for the
|
|
|
|
// specified key space.
|
|
|
|
uint64_t getApproximateSize(KeySpace keySpace) const;
|
|
|
|
|
2018-02-07 22:45:41 +03:00
|
|
|
private:
|
2019-03-13 05:25:54 +03:00
|
|
|
FaultInjector& faultInjector_;
|
2018-02-07 22:45:41 +03:00
|
|
|
RocksHandles dbHandles_;
|
2018-08-03 23:08:37 +03:00
|
|
|
mutable UnboundedQueueExecutor ioPool_;
|
2018-02-07 22:45:41 +03:00
|
|
|
};
|
|
|
|
|
|
|
|
} // namespace eden
|
|
|
|
} // namespace facebook
|