memgraph/include/snapshot/snapshoter.hpp
2016-09-09 16:14:20 +01:00

77 lines
2.1 KiB
C++

#pragma once
#include <unordered_map>
#include "database/db.hpp"
#include "logging/default.hpp"
#include "threading/thread.hpp"
class SnapshotEncoder;
class SnapshotDecoder;
// Captures snapshots.
class Snapshoter
{
public:
// How much sec is between snapshots
// snapshot_folder is path to common folder for all snapshots.
Snapshoter(ConcurrentMap<std::string, Db> &dbs, size_t snapshot_cycle,
std::string &&snapshot_folder);
~Snapshoter();
// Imports latest snapshot into the databse. Multi thread safe.
void import(Db &db);
private:
void run(Logger &logger);
// Makes snapshot of given type
void make_snapshot(std::time_t now, const char *type);
// Makes snapshot. It only saves records which have changed since old_trans.
void snapshot(DbTransaction const &dt, SnapshotEncoder &snap,
tx::TransactionId const &old_trans);
// Loads snapshot. True if success
bool snapshot_load(DbTransaction const &dt, SnapshotDecoder &snap);
std::string snapshot_file(Db &db, std::time_t const &now, const char *type)
{
return snapshot_db_dir(db) + "/" + std::to_string(now) + "_" + type;
}
std::string snapshot_commit_file(Db &db)
{
return snapshot_db_dir(db) + "/snapshot_commit.txt";
}
// Path to directory of database. Ensures that all necessary directorys
// exist.
std::string snapshot_db_dir(Db &db)
{
if (!sys::ensure_directory_exists(snapshot_folder)) {
logger.error("Error while creating directory \"{}\"",
snapshot_folder);
}
auto db_path = snapshot_folder + "/" + db.name();
if (!sys::ensure_directory_exists(db_path)) {
logger.error("Error while creating directory \"{}\"", db_path);
}
return db_path;
}
Logger logger;
const size_t snapshot_cycle;
const size_t max_old_snapshots;
const std::string snapshot_folder;
std::unique_ptr<Thread> thread = {nullptr};
ConcurrentMap<std::string, Db> &dbms;
std::atomic<bool> snapshoting = {true};
};