mirror of
https://github.com/typesense/typesense.git
synced 2025-05-21 06:02:26 +08:00
67 lines
1.8 KiB
C++
67 lines
1.8 KiB
C++
#pragma once
|
|
|
|
#include <stdint.h>
|
|
#include <string>
|
|
#include <rocksdb/db.h>
|
|
#include <rocksdb/options.h>
|
|
|
|
/*
|
|
* Stores all information about a collection.
|
|
* Uses RocksDB for persistence.
|
|
*/
|
|
class Store {
|
|
|
|
private:
|
|
|
|
std::string state_dir_path;
|
|
|
|
rocksdb::DB *db;
|
|
rocksdb::Options options;
|
|
|
|
public:
|
|
|
|
Store() = delete;
|
|
|
|
Store(std::string state_dir_path): state_dir_path(state_dir_path) {
|
|
// Optimize RocksDB. This is the easiest way to get RocksDB to perform well
|
|
options.IncreaseParallelism();
|
|
options.OptimizeLevelStyleCompaction();
|
|
// create the DB if it's not already present
|
|
options.create_if_missing = true;
|
|
options.write_buffer_size = 4*1048576;
|
|
options.max_write_buffer_number = 2;
|
|
|
|
// open DB
|
|
rocksdb::Status s = rocksdb::DB::Open(options, state_dir_path, &db);
|
|
assert(s.ok());
|
|
}
|
|
|
|
~Store() {
|
|
delete db;
|
|
}
|
|
|
|
bool insert(const std::string& key, const std::string& value) {
|
|
rocksdb::Status status = db->Put(rocksdb::WriteOptions(), key, value);
|
|
return status.ok();
|
|
}
|
|
|
|
bool get(const std::string& key, std::string& value) {
|
|
rocksdb::Status status = db->Get(rocksdb::ReadOptions(), key, &value);
|
|
return status.ok();
|
|
}
|
|
|
|
bool remove(const std::string& key) {
|
|
rocksdb::Status status = db->Delete(rocksdb::WriteOptions(), key);
|
|
return status.ok();
|
|
}
|
|
|
|
void print_memory_usage() {
|
|
std::string index_usage;
|
|
db->GetProperty("rocksdb.estimate-table-readers-mem", &index_usage);
|
|
std::cout << "rocksdb.estimate-table-readers-mem: " << index_usage << std::endl;
|
|
|
|
std::string memtable_usage;
|
|
db->GetProperty("rocksdb.cur-size-all-mem-tables", &memtable_usage);
|
|
std::cout << "rocksdb.cur-size-all-mem-tables: " << memtable_usage << std::endl;
|
|
}
|
|
}; |