mirror of
https://github.com/MariaDB/server.git
synced 2025-01-17 20:42:30 +01:00
3bd6e4b8ee
MDEV-3989: Server crashes on import from MariaDB mysqldump export with partitioned Aria table. Problem was that bulk insert in aria was not properly protected against concurrent selects. storage/maria/ha_maria.cc: Move settings of file->state to _ma_block_start_trans() to ensure that lock_key_trees is not changed by a concurrent bulk_insert. storage/maria/ma_check.c: Added DBUG_ASSERT() storage/maria/ma_open.c: Set start_trans to ma_start_trans for default behaviour. storage/maria/ma_pagecrc.c: Removed test for 'non_transactional' as a now_transactinal could be reset while a flush was happening. storage/maria/ma_state.c: Moved setting of info->state from external_lock to start_trans to protect against concurrent running bulk inserts. This works as the other threads will wait in thr_lock() until bulk_insert is done and keys are re-generated. storage/maria/ma_state.h: Added _ma_start_trans()
87 lines
3.5 KiB
C
87 lines
3.5 KiB
C
/* Copyright (C) 2008 Sun AB & Michael Widenius
|
|
|
|
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., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */
|
|
|
|
/* Struct to store tables in use by one transaction */
|
|
|
|
typedef struct st_maria_status_info
|
|
{
|
|
ha_rows records; /* Rows in table */
|
|
ha_rows del; /* Removed rows */
|
|
my_off_t empty; /* lost space in datafile */
|
|
my_off_t key_empty; /* lost space in indexfile */
|
|
my_off_t key_file_length;
|
|
my_off_t data_file_length;
|
|
ha_checksum checksum;
|
|
uint32 changed:1, /* Set if table was changed */
|
|
no_transid:1; /* Set if no transid was set on rows */
|
|
} MARIA_STATUS_INFO;
|
|
|
|
|
|
typedef struct st_used_tables {
|
|
struct st_used_tables *next;
|
|
struct st_maria_share *share;
|
|
MARIA_STATUS_INFO state_current;
|
|
MARIA_STATUS_INFO state_start;
|
|
} MARIA_USED_TABLES;
|
|
|
|
|
|
/* Struct to store commit state at different times */
|
|
|
|
typedef struct st_state_history {
|
|
struct st_state_history *next;
|
|
TrID trid;
|
|
MARIA_STATUS_INFO state;
|
|
} MARIA_STATE_HISTORY;
|
|
|
|
|
|
/* struct to remember history for closed tables */
|
|
|
|
typedef struct st_state_history_closed {
|
|
LSN create_rename_lsn;
|
|
MARIA_STATE_HISTORY *state_history;
|
|
} MARIA_STATE_HISTORY_CLOSED;
|
|
|
|
|
|
my_bool _ma_setup_live_state(MARIA_HA *info);
|
|
MARIA_STATE_HISTORY *_ma_remove_not_visible_states(MARIA_STATE_HISTORY
|
|
*org_history,
|
|
my_bool all,
|
|
my_bool trman_is_locked);
|
|
void _ma_reset_state(MARIA_HA *info);
|
|
void _ma_get_status(void* param, my_bool concurrent_insert);
|
|
void _ma_update_status(void* param);
|
|
void _ma_update_status_with_lock(MARIA_HA *info);
|
|
void _ma_restore_status(void *param);
|
|
void _ma_copy_status(void* to, void *from);
|
|
void _ma_reset_update_flag(void *param, my_bool concurrent_insert);
|
|
my_bool _ma_start_trans(void* param);
|
|
my_bool _ma_check_status(void *param);
|
|
void _ma_block_get_status(void* param, my_bool concurrent_insert);
|
|
void _ma_block_update_status(void *param);
|
|
void _ma_block_restore_status(void *param);
|
|
my_bool _ma_block_check_status(void *param);
|
|
void maria_versioning(MARIA_HA *info, my_bool versioning);
|
|
void _ma_set_share_data_file_length(struct st_maria_share *share,
|
|
ulonglong new_length);
|
|
void _ma_copy_nontrans_state_information(MARIA_HA *info);
|
|
my_bool _ma_trnman_end_trans_hook(TRN *trn, my_bool commit,
|
|
my_bool active_transactions);
|
|
my_bool _ma_row_visible_always(MARIA_HA *info);
|
|
my_bool _ma_row_visible_non_transactional_table(MARIA_HA *info);
|
|
my_bool _ma_row_visible_transactional_table(MARIA_HA *info);
|
|
void _ma_remove_not_visible_states_with_lock(struct st_maria_share *share,
|
|
my_bool all);
|
|
void _ma_remove_table_from_trnman(struct st_maria_share *share, TRN *trn);
|
|
void _ma_reset_history(struct st_maria_share *share);
|