mirror of
https://github.com/MariaDB/server.git
synced 2025-12-21 11:45:43 +01:00
InnoDB binlog files are now backed up along with other InnoDB data by mariadb-backup. The files are copied after backup locks have been released. Backup files created later than the backup LSN are skipped. Then during --prepare, any data missing from the hot-copied binlog files will be restored by the binlog recovery code, and any excess data written after the backup LSN will be zeroed out. A couple test cases test taking a consistent backup of a server with active traffic during the backup, by provisioning a slave from the restored binlog position and checking that the slave can replicate from the original master and get identical data. Signed-off-by: Kristian Nielsen <knielsen@knielsen-hq.org>
40 lines
1 KiB
C++
40 lines
1 KiB
C++
#pragma once
|
|
#include "my_global.h"
|
|
#include "backup_mysql.h"
|
|
#include "datasink.h"
|
|
#include "thread_pool.h"
|
|
#include "xtrabackup.h"
|
|
|
|
#include <unordered_set>
|
|
#include <string>
|
|
#include <vector>
|
|
|
|
namespace common_engine {
|
|
|
|
class BackupImpl;
|
|
|
|
class Backup {
|
|
public:
|
|
Backup(const char *datadir_path, ds_ctxt_t *datasink,
|
|
std::vector<MYSQL *> &con_pool, ThreadPool &thread_pool);
|
|
~Backup();
|
|
Backup (Backup &&other) = delete;
|
|
Backup & operator= (Backup &&other) = delete;
|
|
Backup(const Backup &) = delete;
|
|
Backup & operator= (const Backup &) = delete;
|
|
bool scan(
|
|
const std::unordered_set<table_key_t> &exclude_tables,
|
|
std::unordered_set<table_key_t> *out_processed_tables,
|
|
bool no_lock, bool collect_log_and_stats);
|
|
bool copy_log_tables(bool finalize);
|
|
bool copy_stats_tables();
|
|
bool copy_engine_binlogs(const char *binlog_dir, lsn_t backup_lsn);
|
|
bool wait_for_finish();
|
|
bool close_log_tables();
|
|
void set_post_copy_table_hook(const post_copy_table_hook_t &hook);
|
|
private:
|
|
BackupImpl *m_backup_impl;
|
|
};
|
|
|
|
} // namespace common_engine
|
|
|