2016-09-10 01:48:15 +08:00
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include <mutex>
|
|
|
|
#include <unordered_map>
|
|
|
|
|
|
|
|
#include "logging/default.hpp"
|
|
|
|
#include "transactions/transaction.hpp"
|
|
|
|
|
|
|
|
class SnapshotEncoder;
|
|
|
|
class SnapshotDecoder;
|
|
|
|
class Db;
|
|
|
|
class DbTransaction;
|
|
|
|
|
|
|
|
// Captures snapshots. Only one per database should exist.
|
|
|
|
class SnapshotEngine
|
|
|
|
{
|
|
|
|
|
|
|
|
public:
|
|
|
|
SnapshotEngine(Db &db, std::string const &name);
|
|
|
|
|
|
|
|
~SnapshotEngine() = default;
|
|
|
|
|
|
|
|
// Returns number of succesffuly created snapshots.
|
|
|
|
size_t snapshoted_no() { return snapshoted_no_v.load(); }
|
|
|
|
|
|
|
|
// Imports latest snapshot into the databse. Blocks until other calls don't
|
|
|
|
// end.
|
|
|
|
bool import();
|
|
|
|
|
|
|
|
// Makes snapshot of given type. Blocks until other calls don't end.
|
|
|
|
bool make_snapshot();
|
|
|
|
|
|
|
|
private:
|
|
|
|
// Makes snapshot of given type
|
|
|
|
bool 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,
|
2016-09-10 03:56:53 +08:00
|
|
|
tx::TransactionRead const &old_trans);
|
2016-09-10 01:48:15 +08:00
|
|
|
|
|
|
|
// Loads snapshot. True if success
|
|
|
|
bool snapshot_load(DbTransaction const &dt, SnapshotDecoder &snap);
|
|
|
|
|
|
|
|
std::string snapshot_file(std::time_t const &now, const char *type);
|
|
|
|
|
|
|
|
std::string snapshot_commit_file();
|
|
|
|
|
|
|
|
// Path to directory of database. Ensures that all necessary directorys
|
|
|
|
// exist.
|
|
|
|
std::string snapshot_db_dir();
|
|
|
|
|
|
|
|
Logger logger;
|
|
|
|
|
|
|
|
Db &db;
|
|
|
|
std::mutex guard;
|
|
|
|
const std::string snapshot_folder;
|
|
|
|
std::atomic<size_t> snapshoted_no_v = {0};
|
|
|
|
};
|