mirror of
https://github.com/MariaDB/server.git
synced 2025-02-10 15:35:34 +01:00
![Thirunarayanan Balathandayuthapani](/assets/img/avatar_default.png)
trx_sys_t::undo_log_nonempty: Set to true if there are undo logs to rollback and purge. The algorithm for re-creating the undo tablespace when trx_sys_t::undo_log_nonempty is disabled: 1) trx_sys_t::reset_page(): Reset the TRX_SYS page and assign all rollback segment slots from 1..127 to FIL_NULL 2) Free the rollback segment header page of system tablespace for the slots 1..127 3) Update the binlog and WSREP information in system tablespace rollback segment header Step (1), (2) and Step (3) should happen atomically within a single mini-transaction. 4) srv_undo_delete_old_tablespaces(): Delete the old undo tablespaces present in the undo log directory 5) Make checkpoint to get rid of old undo log tablespaces redo logs 6) Assign new start space id for the undo log tablespaces 7) Re-create the specified undo log tablespaces. InnoDB uses same mtr for this one and step (6) 8) Make checkpoint again, so that server or mariabackup can read the undo log tablespace page0 before applying the redo logs srv_undo_tablespaces_reinit(): Recreate the undo log tablespaces. It does reset trx_sys page, delete the old undo tablespaces, update the binlog offset, write set replication checkpoint in system rollback segment page trx_rseg_update_binlog_offset(): Added 2 new parameters to pass binlog file name and binlog offset trx_rseg_array_init(): Return error if the rollback segment slot points to non-existent tablespace srv_undo_tablespaces_init(): Added new parameter mtr to initialize all undo tablespaces trx_assign_rseg_low(): Allow the transaction to use the rollback segment slots(1..127) even if InnoDB failed to change to the requested innodb_undo_tablespaces=0 srv_start(): Override the user specified value of innodb_undo_tablespaces variable with already existing actual undo tablespaces wf_incremental_process(): Detects whether TRX_SYS page has been modified since last backup. If it is then incremental backup fails and throws the information about taking full backup again xb_assign_undo_space_start(): Removed the function. Because undo001 has first undo space id value in page0 Added test case to test the scenario during startup and mariabackup incremental process too. Reviewed-by : Marko Mäkelä Tested-by : Matthias Leich
124 lines
4.2 KiB
C
124 lines
4.2 KiB
C
/*****************************************************************************
|
|
|
|
Copyright (c) 1995, 2017, Oracle and/or its affiliates. All Rights Reserved.
|
|
Copyright (c) 2017, 2022, MariaDB Corporation.
|
|
|
|
This program is free software; you can redistribute it and/or modify it under
|
|
the terms of the GNU General Public License as published by the Free Software
|
|
Foundation; version 2 of the License.
|
|
|
|
This program is distributed in the hope that it will be useful, but WITHOUT
|
|
ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
|
|
FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
|
|
|
|
You should have received a copy of the GNU General Public License along with
|
|
this program; if not, write to the Free Software Foundation, Inc.,
|
|
51 Franklin Street, Fifth Floor, Boston, MA 02110-1335 USA
|
|
|
|
*****************************************************************************/
|
|
|
|
/**************************************************//**
|
|
@file include/srv0start.h
|
|
Starts the Innobase database server
|
|
|
|
Created 10/10/1995 Heikki Tuuri
|
|
*******************************************************/
|
|
|
|
#pragma once
|
|
|
|
#include "log0log.h"
|
|
#include "ut0byte.h"
|
|
|
|
// Forward declaration
|
|
struct dict_table_t;
|
|
|
|
/** Open the configured number of dedicated undo tablespaces.
|
|
@param[in] create_new_undo whether the undo tablespaces has to be created
|
|
@param[in,out] mtr mini-transaction
|
|
@return DB_SUCCESS or error code */
|
|
dberr_t srv_undo_tablespaces_init(bool create_new_undo, mtr_t *mtr);
|
|
|
|
/** Start InnoDB.
|
|
@param[in] create_new_db whether to create a new database
|
|
@return DB_SUCCESS or error code */
|
|
dberr_t srv_start(bool create_new_db);
|
|
|
|
/**
|
|
Shutdown purge to make sure that there is no possibility that we call any
|
|
plugin code (e.g., audit) inside virtual column computation.
|
|
*/
|
|
void innodb_preshutdown();
|
|
|
|
/** Shut down InnoDB. */
|
|
void innodb_shutdown();
|
|
|
|
/*************************************************************//**
|
|
Copy the file path component of the physical file to parameter. It will
|
|
copy up to and including the terminating path separator.
|
|
@return number of bytes copied or ULINT_UNDEFINED if destination buffer
|
|
is smaller than the path to be copied. */
|
|
ulint
|
|
srv_path_copy(
|
|
/*==========*/
|
|
char* dest, /*!< out: destination buffer */
|
|
ulint dest_len, /*!< in: max bytes to copy */
|
|
const char* basedir, /*!< in: base directory */
|
|
const char* table_name) /*!< in: source table name */
|
|
MY_ATTRIBUTE((nonnull, warn_unused_result));
|
|
|
|
/** Get the meta-data filename from the table name for a
|
|
single-table tablespace.
|
|
@param[in] table table object
|
|
@param[out] filename filename
|
|
@param[in] max_len filename max length */
|
|
void
|
|
srv_get_meta_data_filename(
|
|
dict_table_t* table,
|
|
char* filename,
|
|
ulint max_len);
|
|
|
|
/** Get the encryption-data filename from the table name for a
|
|
single-table tablespace.
|
|
@param[in] table table object
|
|
@param[out] filename filename
|
|
@param[in] max_len filename max length */
|
|
void
|
|
srv_get_encryption_data_filename(
|
|
dict_table_t* table,
|
|
char* filename,
|
|
ulint max_len);
|
|
|
|
/** Log sequence number at shutdown */
|
|
extern lsn_t srv_shutdown_lsn;
|
|
|
|
/** TRUE if the server is being started */
|
|
extern bool srv_is_being_started;
|
|
/** TRUE if the server is being started, before rolling back any
|
|
incomplete transactions */
|
|
extern bool srv_startup_is_before_trx_rollback_phase;
|
|
|
|
/** TRUE if a raw partition is in use */
|
|
extern ibool srv_start_raw_disk_in_use;
|
|
|
|
/** Shutdown state */
|
|
enum srv_shutdown_t {
|
|
SRV_SHUTDOWN_NONE = 0, /*!< Database running normally */
|
|
/** Shutdown initiated in srv_shutdown_bg_undo_sources() */
|
|
SRV_SHUTDOWN_INITIATED,
|
|
SRV_SHUTDOWN_CLEANUP, /*!< Cleaning up in
|
|
logs_empty_and_mark_files_at_shutdown() */
|
|
SRV_SHUTDOWN_LAST_PHASE,/*!< Last phase after ensuring that
|
|
the buffer pool can be freed: flush
|
|
all file spaces and close all files */
|
|
SRV_SHUTDOWN_EXIT_THREADS/*!< Exit all threads */
|
|
};
|
|
|
|
/** Whether any undo log records can be generated */
|
|
extern bool srv_undo_sources;
|
|
|
|
/** At a shutdown this value climbs from SRV_SHUTDOWN_NONE to
|
|
SRV_SHUTDOWN_CLEANUP and then to SRV_SHUTDOWN_LAST_PHASE, and so on */
|
|
extern enum srv_shutdown_t srv_shutdown_state;
|
|
|
|
/** Files comprising the system tablespace */
|
|
extern pfs_os_file_t files[1000];
|