51#include <unordered_map>
52#include <unordered_set>
62extern std::list<std::pair<space_id_t, lsn_t>> index_load_list;
64extern volatile lsn_t backup_redo_log_flushed_lsn;
81void meb_scan_log_seg(
byte *
buf,
size_t buf_len,
lsn_t *scanned_lsn,
82 uint32_t *scanned_checkpoint_no, uint32_t *block_no,
83 size_t *n_bytes_scanned,
bool *has_encrypted_log);
107void meb_apply_log_recs(
void);
113void meb_apply_log_recs_via_callback(
115 void (*wait_till_done_function)());
143bool meb_scan_log_recs(
size_t available_memory,
const byte *
buf,
size_t len,
185size_t meb_heap_used();
249#if defined(UNIV_DEBUG) || defined(UNIV_HOTBACKUP)
384 std::unordered_map<page_no_t, recv_addr_t *, std::hash<page_no_t>,
385 std::equal_to<page_no_t>>;
405 using Spaces = std::unordered_map<space_id_t, Space, std::hash<space_id_t>,
406 std::equal_to<space_id_t>>;
439 using Mlog_records = std::vector<Mlog_record, ut::allocator<Mlog_record>>;
484 saved_rec.space_id = space_id;
485 saved_rec.page_no = page_no;
486 saved_rec.type =
type;
487 saved_rec.body = body;
488 saved_rec.size =
len;
514 space_id = saved_rec.space_id;
515 page_no = saved_rec.page_no;
516 type = saved_rec.type;
517 body =
const_cast<byte *
>(saved_rec.body);
518 len = saved_rec.size;
523#ifndef UNIV_HOTBACKUP
544 bool apply_file_operations;
676#define RECV_SCAN_SIZE (4 * UNIV_PAGE_SIZE)
uint32_t space_id_t
Tablespace identifier.
Definition: api0api.h:47
uint32_t page_no_t
Page number.
Definition: api0api.h:45
The database buffer pool global types for the directory.
buf_flush_t
Flags for flush types.
Definition: buf0types.h:68
Definition: sql_list.h:467
Redo recovery configuration.
Definition: buf0dblwr.h:475
A counter which tracks number of things left to do, which can be incremented or decremented,...
Definition: ut0todo_counter.h:41
Allocator that allows std::* containers to manage their memory through ut::malloc* and ut::free libra...
Definition: ut0new.h:2182
dberr_t
Definition: db0err.h:39
Data dictionary global types.
ib_id_t table_id_t
Table or partition identifier (unique within an InnoDB instance).
Definition: dict0types.h:232
mysql_service_status_t recv(const char *tag, const unsigned char *data, size_t data_length) noexcept
Definition: gr_message_service_example.cc:39
The simple hash table utility.
bool recv_is_making_a_backup
true When the redo log is being backed up
Definition: log0recv.cc:175
static bool log_block_checksum_is_ok(const byte *block)
Check the 4-byte checksum to the trailer checksum field of a log block.
Definition: log0recv.cc:623
bool recv_no_ibuf_operations
If the following is true, the buffer pool file pages must be invalidated after recovery and no ibuf o...
Definition: log0recv.cc:172
MetadataRecover * recv_recovery_from_checkpoint_finish(bool aborting)
Complete the recovery from the latest checkpoint.
Definition: log0recv.cc:4108
void recv_sys_free()
Frees the recovery system.
Definition: log0recv.cc:772
void recv_sys_init()
Inits the recovery system for a recovery operation.
Definition: log0recv.cc:534
recv_addr_state
States of recv_addr_t.
Definition: log0recv.h:293
@ RECV_BEING_READ
page is being read
Definition: log0recv.h:299
@ RECV_DISCARDED
log records have been discarded because the tablespace does not exist
Definition: log0recv.h:309
@ RECV_BEING_PROCESSED
log records are being applied on the page
Definition: log0recv.h:302
@ RECV_NOT_PROCESSED
not yet processed
Definition: log0recv.h:296
@ RECV_PROCESSED
log records have been applied on the page
Definition: log0recv.h:305
lsn_t recv_calc_lsn_on_data_add(lsn_t lsn, os_offset_t len)
Calculates the new value for lsn when more data is added to the log.
Definition: log0recv.cc:240
void recv_sys_close()
Release recovery system mutexes.
Definition: log0recv.cc:419
constexpr uint32_t RECV_PARSING_BUF_SIZE
Size of the parsing buffer; it must accommodate RECV_SCAN_SIZE many times!
Definition: log0recv.h:672
dberr_t recv_verify_log_is_clean_pre_8_0_30(log_t &log)
Determine if a redo log from a version before MySQL 8.0.30 is clean.
Definition: log0recv.cc:824
size_t recv_n_frames_for_pages_per_pool_instance
This many blocks must be left in each Buffer Pool instance to be managed by the LRU when we scan the ...
Definition: log0recv.cc:198
void recv_sys_var_init()
Reset the state of the recovery system variables.
Definition: log0recv.cc:457
bool recv_page_is_brand_new(buf_block_t *block)
Returns true if the page is brand new (the next log record is init_file_page or no records to apply).
Definition: log0recv.cc:2552
void recv_apply_hashed_log_recs(log_t &log, bool allow_ibuf)
Empties the hash table of stored log records, applying them to appropriate pages.
Definition: log0recv.cc:1166
static void recv_recover_page(bool jri, buf_block_t *block)
Wrapper for recv_recover_page_func().
Definition: log0recv.h:170
const char * get_mlog_string(mlog_id_t type)
Return string name of the redo log record type.
Definition: log0recv.cc:4173
recv_sys_t * recv_sys
The recovery system.
Definition: log0recv.cc:98
bool recv_needed_recovery
true when recv_init_crash_recovery() has been called.
Definition: log0recv.cc:156
void recv_sys_create()
Creates the recovery system.
Definition: log0recv.cc:337
static bool recv_recovery_is_on()
Returns true if recovery is currently running.
volatile bool recv_recovery_on
true when applying redo log records during crash recovery; false otherwise.
Definition: log0recv.cc:103
bool recv_lsn_checks_on
true if buf_page_is_corrupted() should check if the log sequence number (FIL_PAGE_LSN) is in the futu...
Definition: log0recv.cc:161
void recv_recover_page_func(bool just_read_in, buf_block_t *block)
Applies the hashed log records to the page, if the page lsn is less than the lsn of a log record.
Definition: log0recv.cc:2592
dberr_t recv_recovery_from_checkpoint_start(log_t &log, lsn_t flush_lsn)
Start recovering from a redo log checkpoint.
Definition: log0recv.cc:3901
uint64_t lsn_t
Type used for all log sequence number storage and arithmetic.
Definition: log0types.h:63
Mini-transaction buffer global types.
mlog_id_t
Definition: mtr0types.h:63
Definition: buf0block_hint.cc:30
Definition: buf0dblwr.cc:75
Cursor end()
A past-the-end Cursor.
Definition: rules_table_service.cc:192
std::map< Key, Value, Compare, ut::allocator< std::pair< const Key, Value > > > map
Specialization of map which uses ut_allocator.
Definition: ut0new.h:2893
The interface to the operating system file io.
uint64_t os_offset_t
File offset in bytes.
Definition: os0file.h:87
required uint64 version
Definition: replication_group_member_actions.proto:41
required string type
Definition: replication_group_member_actions.proto:34
case opt name
Definition: sslopt-case.h:29
The buffer control block structure.
Definition: buf0buf.h:1747
Redo log - single data structure with state of the redo log system.
Definition: log0sys.h:77
The info structure stored at the beginning of a heap block.
Definition: mem0mem.h:302
InnoDB condition variable.
Definition: os0event.cc:63
Hashed page file address struct.
Definition: log0recv.h:313
page_no_t page_no
Page number.
Definition: log0recv.h:323
recv_addr_state state
recovery state of the page
Definition: log0recv.h:317
space_id_t space
Space ID.
Definition: log0recv.h:320
List rec_list
List of log records for this page.
Definition: log0recv.h:326
Block of log record data.
Definition: log0recv.h:257
recv_data_t * next
pointer to the next block or NULL.
Definition: log0recv.h:262
Definition: log0recv.h:409
byte * ptr
Encryption key.
Definition: log0recv.h:417
space_id_t space_id
Tablespace ID.
Definition: log0recv.h:411
byte * iv
Encryption IV.
Definition: log0recv.h:420
lsn_t lsn
LSN of REDO log encryption entry.
Definition: log0recv.h:414
Mini transaction log record.
Definition: log0recv.h:426
space_id_t space_id
Definition: log0recv.h:428
size_t size
Definition: log0recv.h:436
const byte * body
Definition: log0recv.h:434
page_no_t page_no
Definition: log0recv.h:430
mlog_id_t type
Definition: log0recv.h:432
Every space has its own heap and pages that belong to it.
Definition: log0recv.h:388
Pages m_pages
Pages that need to be recovered.
Definition: log0recv.h:400
mem_heap_t * m_heap
Memory heap of log records and file addresses.
Definition: log0recv.h:397
Space(mem_heap_t *heap)
Constructor.
Definition: log0recv.h:391
Space()
Default constructor.
Definition: log0recv.h:394
Recovery system data structure.
Definition: log0recv.h:382
std::vector< Encryption_Key > Encryption_Keys
Definition: log0recv.h:423
Missing_Ids deleted
Tablespace IDs that were explicitly deleted.
Definition: log0recv.h:637
ulint len
Amount of data in buf.
Definition: log0recv.h:559
bool found_corrupt_fs
Set when an inconsistency with the file system contents is detected during log scan or apply.
Definition: log0recv.h:601
ib_mutex_t mutex
mutex protecting the fields apply_log_recs, decrements of n_pages_to_recover, and the state field in ...
Definition: log0recv.h:527
bool is_meb_db
Data directory has been recognized as data directory from MEB.
Definition: log0recv.h:607
lsn_t previous_recovered_lsn
The previous value of recovered_lsn - before we parsed the last mtr.
Definition: log0recv.h:588
ulint bytes_to_ignore_before_checkpoint
Number of data bytes to ignore until we reach checkpoint_lsn.
Definition: log0recv.h:570
os_event_t flush_end
event to signal that the page cleaner has finished the request
Definition: log0recv.h:537
void save_rec(size_t rec_num, space_id_t space_id, page_no_t page_no, mlog_id_t type, const byte *body, size_t len)
Save mlog record information.
Definition: log0recv.h:469
dblwr::recv::DBLWR * dblwr
Doublewrite buffer pages, destroyed after recovery completes.
Definition: log0recv.h:624
Spaces * spaces
Hash table of pages, indexed by SpaceID.
Definition: log0recv.h:615
lsn_t recovered_lsn
The log records have been parsed up to this lsn.
Definition: log0recv.h:582
std::vector< Mlog_record, ut::allocator< Mlog_record > > Mlog_records
Definition: log0recv.h:439
ut::Todo_counter n_pages_to_recover
Number of unique unprocessed page ids in the spaces nested hash table.
Definition: log0recv.h:621
ulint recovered_offset
Start offset of non-parsed log records in buf.
Definition: log0recv.h:579
lsn_t last_block_first_mtr_boundary
Tracks what should be the proper value of first_rec_group field in the header of the block to which r...
Definition: log0recv.h:593
std::unordered_map< page_no_t, recv_addr_t *, std::hash< page_no_t >, std::equal_to< page_no_t > > Pages
Definition: log0recv.h:385
std::unordered_map< space_id_t, Space, std::hash< space_id_t >, std::equal_to< space_id_t > > Spaces
Definition: log0recv.h:406
ib_mutex_t writer_mutex
mutex coordinating flushing between recv_writer_thread and the recovery thread.
Definition: log0recv.h:531
bool get_saved_rec(size_t rec_num, space_id_t &space_id, page_no_t &page_no, mlog_id_t &type, const byte *&body, size_t &len)
Return saved mlog record information, if there.
Definition: log0recv.h:500
Mlog_records saved_recs
Definition: log0recv.h:640
bool is_cloned_db
Data directory has been recognized as cloned data directory.
Definition: log0recv.h:604
os_event_t flush_start
event to activate page cleaner threads
Definition: log0recv.h:534
Missing_Ids missing_ids
Tablespace IDs that were ignored during redo log apply.
Definition: log0recv.h:634
std::unordered_set< space_id_t > Missing_Ids
Definition: log0recv.h:403
lsn_t checkpoint_lsn
Checkpoint lsn that was used during recovery (read from file).
Definition: log0recv.h:567
uint32_t scanned_epoch_no
The log data has been scanned up to this epoch_no.
Definition: log0recv.h:576
size_t buf_len
Size of the parsing buffer.
Definition: log0recv.h:556
buf_flush_t flush_type
type of the flush request.
Definition: log0recv.h:541
Encryption_Keys * keys
Encryption Key information per tablespace ID.
Definition: log0recv.h:631
bool dblwr_state
Doublewrite buffer state before MEB recovery starts.
Definition: log0recv.h:612
bool found_corrupt_log
Set when finding a corrupt log block or record, or there is a log parsing buffer overflow.
Definition: log0recv.h:597
lsn_t parse_start_lsn
This is the lsn from which we were able to start parsing log records and adding them to the hash tabl...
Definition: log0recv.h:564
lsn_t scanned_lsn
The log data has been scanned up to this lsn.
Definition: log0recv.h:573
byte * buf
Buffer for parsing log records.
Definition: log0recv.h:553
bool apply_log_recs
This is true when log rec application to pages is allowed; this flag tells the i/o-handler if it shou...
Definition: log0recv.h:550
MetadataRecover * metadata_recover
We store and merge all table persistent data here during scanning redo logs.
Definition: log0recv.h:628
static constexpr size_t MAX_SAVED_MLOG_RECS
While scanning logs for multi-record mini-transaction (mtr), we have two passes.
Definition: log0recv.h:459
Stored log record struct.
Definition: log0recv.h:266
recv_data_t * data
Chain of blocks containing the log record body.
Definition: log0recv.h:276
lsn_t start_lsn
Start lsn of the log segment written by the mtr which generated this log record: NOTE that this is no...
Definition: log0recv.h:281
UT_LIST_NODE_T(recv_t) Node
Definition: log0recv.h:267
ulint len
Log record body length in bytes.
Definition: log0recv.h:273
lsn_t end_lsn
End lsn of the log segment written by the mtr which generated this log record: NOTE that this is not ...
Definition: log0recv.h:286
Node rec_list
List node, list anchored in recv_addr_t.
Definition: log0recv.h:289
mlog_id_t type
Log record type.
Definition: log0recv.h:270
typedef UT_LIST_BASE_NODE_T(rw_lock_t, list) rw_lock_list_t
#define UNIV_NOTHROW
Definition: univ.i:456
unsigned long int ulint
Definition: univ.i:406
Utilities for byte operations.
#define ut_ad(EXPR)
Debug assertion.
Definition: ut0dbg.h:105
#define UT_LIST_NODE_T(t)
Macro used for legacy reasons.
Definition: ut0lst.h:64
Dynamic memory allocation routines and custom allocators specifically crafted to support memory instr...
static uint64_t lsn
Definition: xcom_base.cc:446