2016-09-10 01:48:15 +08:00
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include <mutex>
|
|
|
|
#include <unordered_map>
|
|
|
|
|
|
|
|
#include "logging/default.hpp"
|
2016-09-14 00:02:04 +08:00
|
|
|
#include "storage/indexes/index_definition.hpp"
|
2016-09-10 01:48:15 +08:00
|
|
|
#include "transactions/transaction.hpp"
|
|
|
|
|
|
|
|
class SnapshotEncoder;
|
|
|
|
class SnapshotDecoder;
|
|
|
|
class Db;
|
|
|
|
class DbTransaction;
|
2016-09-12 04:30:31 +08:00
|
|
|
class DbAccessor;
|
2016-09-10 01:48:15 +08:00
|
|
|
|
|
|
|
// Captures snapshots. Only one per database should exist.
|
|
|
|
class SnapshotEngine
|
|
|
|
{
|
|
|
|
|
|
|
|
public:
|
2016-09-13 03:13:04 +08:00
|
|
|
SnapshotEngine(Db &db);
|
2016-09-10 01:48:15 +08:00
|
|
|
|
|
|
|
~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:
|
2016-09-12 05:22:52 +08:00
|
|
|
// Removes excess of snapshots starting with oldest one.
|
|
|
|
void clean_snapshots();
|
|
|
|
|
2016-09-10 01:48:15 +08:00
|
|
|
// 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
|
|
|
|
2016-09-14 00:02:04 +08:00
|
|
|
// Loads snapshot. True if success. Returns indexes which were in snapshot.
|
|
|
|
std::vector<IndexDefinition> snapshot_load(DbAccessor &t,
|
|
|
|
SnapshotDecoder &snap);
|
2016-09-10 01:48:15 +08:00
|
|
|
|
2016-09-14 00:02:04 +08:00
|
|
|
// Adds indexes. Should be called outside transactions.
|
|
|
|
void add_indexes(std::vector<IndexDefinition> &v);
|
|
|
|
|
|
|
|
// Will return different name on every call.
|
2016-09-10 01:48:15 +08:00
|
|
|
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;
|
2016-09-12 05:22:52 +08:00
|
|
|
|
|
|
|
// Determines how many newest snapshot will be preserved, while the other
|
|
|
|
// ones will be deleted.
|
|
|
|
const size_t max_retained_snapshots;
|
|
|
|
|
2016-09-10 01:48:15 +08:00
|
|
|
std::atomic<size_t> snapshoted_no_v = {0};
|
|
|
|
};
|