mirror of
https://github.com/MariaDB/server.git
synced 2025-01-27 01:04:19 +01:00
Merge 10.11 into 11.1
This commit is contained in:
commit
94999c16cc
9 changed files with 96 additions and 9 deletions
extra/mariabackup
mysql-test/suite/innodb
r
t
sql
storage/innobase
|
@ -1600,11 +1600,11 @@ struct my_option xb_client_options[]= {
|
||||||
GET_BOOL, NO_ARG, 0, 0, 0, 0, 0, 0},
|
GET_BOOL, NO_ARG, 0, 0, 0, 0, 0, 0},
|
||||||
|
|
||||||
{"rsync", OPT_RSYNC,
|
{"rsync", OPT_RSYNC,
|
||||||
"Obsolete depricated option",
|
"Obsolete, deprecated option",
|
||||||
&ignored_option, &ignored_option, 0, GET_BOOL, NO_ARG, 0, 0, 0, 0, 0, 0},
|
&ignored_option, &ignored_option, 0, GET_BOOL, NO_ARG, 0, 0, 0, 0, 0, 0},
|
||||||
|
|
||||||
{"no-backup-locks", OPT_NO_BACKUP_LOCKS,
|
{"no-backup-locks", OPT_NO_BACKUP_LOCKS,
|
||||||
"Obsolete depricated option",
|
"Obsolete, deprecated option",
|
||||||
&ignored_option, &ignored_option, 0, GET_BOOL, NO_ARG, 0, 0, 0, 0, 0, 0},
|
&ignored_option, &ignored_option, 0, GET_BOOL, NO_ARG, 0, 0, 0, 0, 0, 0},
|
||||||
|
|
||||||
{"force-non-empty-directories", OPT_FORCE_NON_EMPTY_DIRS,
|
{"force-non-empty-directories", OPT_FORCE_NON_EMPTY_DIRS,
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
SET GLOBAL innodb_fast_shutdown=0;
|
SET GLOBAL innodb_fast_shutdown=0;
|
||||||
# restart: --innodb-data-home-dir=MYSQLTEST_VARDIR/tmp/row_format_redundant --innodb-log-group-home-dir=MYSQLTEST_VARDIR/tmp/row_format_redundant --innodb-data-file-path=ibdata1:1M:autoextend --innodb-undo-tablespaces=0 --innodb-stats-persistent=0
|
# restart: --innodb-data-home-dir=MYSQLTEST_VARDIR/tmp/row_format_redundant --innodb-log-group-home-dir=MYSQLTEST_VARDIR/tmp/row_format_redundant --innodb-data-file-path=ibdata1:1M:autoextend --innodb_undo_directory=MYSQLTEST_VARDIR/tmp/undo_dir --innodb-undo-tablespaces=0 --innodb-stats-persistent=0
|
||||||
#
|
#
|
||||||
# Bug#21644827 - FTS, ASSERT !SRV_READ_ONLY_MODE || M_IMPL.M_LOG_MODE ==
|
# Bug#21644827 - FTS, ASSERT !SRV_READ_ONLY_MODE || M_IMPL.M_LOG_MODE ==
|
||||||
# MTR_LOG_NO_REDO
|
# MTR_LOG_NO_REDO
|
||||||
|
@ -25,7 +25,7 @@ c varchar(150), index k1(c(99), b(56)), index k2(b(5), c(10))) engine=InnoDB
|
||||||
row_format=redundant;
|
row_format=redundant;
|
||||||
insert into t3 values(444, 'dddd', 'bbbbb', 'aaaaa');
|
insert into t3 values(444, 'dddd', 'bbbbb', 'aaaaa');
|
||||||
insert into t3 values(555, 'eeee', 'ccccc', 'aaaaa');
|
insert into t3 values(555, 'eeee', 'ccccc', 'aaaaa');
|
||||||
# restart: --innodb-data-home-dir=MYSQLTEST_VARDIR/tmp/row_format_redundant --innodb-log-group-home-dir=MYSQLTEST_VARDIR/tmp/row_format_redundant --innodb-data-file-path=ibdata1:1M:autoextend --innodb-undo-tablespaces=0 --innodb-stats-persistent=0 --innodb-read-only
|
# restart: --innodb-data-home-dir=MYSQLTEST_VARDIR/tmp/row_format_redundant --innodb-log-group-home-dir=MYSQLTEST_VARDIR/tmp/row_format_redundant --innodb-data-file-path=ibdata1:1M:autoextend --innodb_undo_directory=MYSQLTEST_VARDIR/tmp/undo_dir --innodb-undo-tablespaces=0 --innodb-stats-persistent=0 --innodb-read-only
|
||||||
SELECT COUNT(*) FROM t1;
|
SELECT COUNT(*) FROM t1;
|
||||||
COUNT(*)
|
COUNT(*)
|
||||||
4096
|
4096
|
||||||
|
@ -41,14 +41,14 @@ TRUNCATE TABLE t2;
|
||||||
ERROR HY000: Table 't2' is read only
|
ERROR HY000: Table 't2' is read only
|
||||||
TRUNCATE TABLE t3;
|
TRUNCATE TABLE t3;
|
||||||
ERROR HY000: Table 't3' is read only
|
ERROR HY000: Table 't3' is read only
|
||||||
# restart: --innodb-data-home-dir=MYSQLTEST_VARDIR/tmp/row_format_redundant --innodb-log-group-home-dir=MYSQLTEST_VARDIR/tmp/row_format_redundant --innodb-data-file-path=ibdata1:1M:autoextend --innodb-undo-tablespaces=0 --innodb-stats-persistent=0 --skip-innodb-fast-shutdown
|
# restart: --innodb-data-home-dir=MYSQLTEST_VARDIR/tmp/row_format_redundant --innodb-log-group-home-dir=MYSQLTEST_VARDIR/tmp/row_format_redundant --innodb-data-file-path=ibdata1:1M:autoextend --innodb_undo_directory=MYSQLTEST_VARDIR/tmp/undo_dir --innodb-undo-tablespaces=0 --innodb-stats-persistent=0 --skip-innodb-fast-shutdown
|
||||||
TRUNCATE TABLE t1;
|
TRUNCATE TABLE t1;
|
||||||
TRUNCATE TABLE t2;
|
TRUNCATE TABLE t2;
|
||||||
TRUNCATE TABLE t3;
|
TRUNCATE TABLE t3;
|
||||||
corrupted SYS_TABLES.MIX_LEN for test/t1
|
corrupted SYS_TABLES.MIX_LEN for test/t1
|
||||||
corrupted SYS_TABLES.MIX_LEN for test/t2
|
corrupted SYS_TABLES.MIX_LEN for test/t2
|
||||||
corrupted SYS_TABLES.MIX_LEN for test/t3
|
corrupted SYS_TABLES.MIX_LEN for test/t3
|
||||||
# restart: --innodb-data-home-dir=MYSQLTEST_VARDIR/tmp/row_format_redundant --innodb-log-group-home-dir=MYSQLTEST_VARDIR/tmp/row_format_redundant --innodb-data-file-path=ibdata1:1M:autoextend --innodb-undo-tablespaces=0 --innodb-stats-persistent=0 --skip-innodb-fast-shutdown
|
# restart: --innodb-data-home-dir=MYSQLTEST_VARDIR/tmp/row_format_redundant --innodb-log-group-home-dir=MYSQLTEST_VARDIR/tmp/row_format_redundant --innodb-data-file-path=ibdata1:1M:autoextend --innodb_undo_directory=MYSQLTEST_VARDIR/tmp/undo_dir --innodb-undo-tablespaces=0 --innodb-stats-persistent=0 --skip-innodb-fast-shutdown
|
||||||
TRUNCATE TABLE t1;
|
TRUNCATE TABLE t1;
|
||||||
ERROR 42S02: Table 'test.t1' doesn't exist in engine
|
ERROR 42S02: Table 'test.t1' doesn't exist in engine
|
||||||
TRUNCATE TABLE t2;
|
TRUNCATE TABLE t2;
|
||||||
|
|
|
@ -62,3 +62,27 @@ SELECT @@global.innodb_undo_tablespaces;
|
||||||
# Should list 2 undo log tablespaces, not 4
|
# Should list 2 undo log tablespaces, not 4
|
||||||
undo001
|
undo001
|
||||||
undo002
|
undo002
|
||||||
|
#
|
||||||
|
# MDEV-34200 InnoDB tries to write to read-only
|
||||||
|
# system tablespace in buf_dblwr_t::init_or_load_pages()
|
||||||
|
#
|
||||||
|
SET GLOBAL innodb_fast_shutdown=0;
|
||||||
|
# restart: --innodb_undo_tablespaces=4
|
||||||
|
# Should list 4 undo log tablespaces
|
||||||
|
undo001
|
||||||
|
undo002
|
||||||
|
undo003
|
||||||
|
undo004
|
||||||
|
set global innodb_fast_shutdown=0;
|
||||||
|
# restart: --innodb_read_only=1
|
||||||
|
set global innodb_fast_shutdown=0;
|
||||||
|
# restart: --innodb-data-file-path=ibdata1:1M:autoextend --innodb_undo_directory=MYSQLTEST_VARDIR/tmp/undo_dir --innodb-data-home-dir=MYSQLTEST_VARDIR/tmp/bugdir --innodb-log-group-home-dir=MYSQLTEST_VARDIR/tmp/bugdir --innodb_undo_tablespaces=3
|
||||||
|
# Should list 3 undo log tablespaces
|
||||||
|
undo001
|
||||||
|
undo002
|
||||||
|
undo003
|
||||||
|
set global innodb_fast_shutdown=0;
|
||||||
|
# restart: --innodb-data-file-path=ibdata1:1M:autoextend --innodb_undo_directory=MYSQLTEST_VARDIR/tmp/undo_dir --innodb-data-home-dir=MYSQLTEST_VARDIR/tmp/bugdir_1 --innodb-log-group-home-dir=MYSQLTEST_VARDIR/tmp/bugdir_1 --innodb_undo_tablespaces=0
|
||||||
|
# Shouldn't list 0 undo log tablespaces
|
||||||
|
set global innodb_fast_shutdown=0;
|
||||||
|
# restart
|
||||||
|
|
|
@ -16,11 +16,14 @@ let INNODB_PAGE_SIZE=`select @@innodb_page_size`;
|
||||||
|
|
||||||
let bugdir= $MYSQLTEST_VARDIR/tmp/row_format_redundant;
|
let bugdir= $MYSQLTEST_VARDIR/tmp/row_format_redundant;
|
||||||
--mkdir $bugdir
|
--mkdir $bugdir
|
||||||
|
let undodir= $MYSQLTEST_VARDIR/tmp/undo_dir;
|
||||||
|
--mkdir $undodir
|
||||||
|
|
||||||
--let SEARCH_FILE = $MYSQLTEST_VARDIR/log/mysqld.1.err
|
--let SEARCH_FILE = $MYSQLTEST_VARDIR/log/mysqld.1.err
|
||||||
|
|
||||||
--let $d=--innodb-data-home-dir=$bugdir --innodb-log-group-home-dir=$bugdir
|
--let $d=--innodb-data-home-dir=$bugdir --innodb-log-group-home-dir=$bugdir
|
||||||
--let $d=$d --innodb-data-file-path=ibdata1:1M:autoextend
|
--let $d=$d --innodb-data-file-path=ibdata1:1M:autoextend
|
||||||
--let $d=$d --innodb-undo-tablespaces=0 --innodb-stats-persistent=0
|
--let $d=$d --innodb_undo_directory=$undodir --innodb-undo-tablespaces=0 --innodb-stats-persistent=0
|
||||||
--let $restart_parameters= $d
|
--let $restart_parameters= $d
|
||||||
# Ensure that any DDL records from previous tests have been purged.
|
# Ensure that any DDL records from previous tests have been purged.
|
||||||
SET GLOBAL innodb_fast_shutdown=0;
|
SET GLOBAL innodb_fast_shutdown=0;
|
||||||
|
@ -153,6 +156,7 @@ DROP TABLE t2,t3;
|
||||||
--list_files $bugdir
|
--list_files $bugdir
|
||||||
--remove_files_wildcard $bugdir
|
--remove_files_wildcard $bugdir
|
||||||
--rmdir $bugdir
|
--rmdir $bugdir
|
||||||
|
--rmdir $undodir
|
||||||
|
|
||||||
# Remove the data file, because DROP TABLE skipped it for the "corrupted" table
|
# Remove the data file, because DROP TABLE skipped it for the "corrupted" table
|
||||||
--let MYSQLD_DATADIR=`select @@datadir`
|
--let MYSQLD_DATADIR=`select @@datadir`
|
||||||
|
|
|
@ -29,12 +29,15 @@ let MYSQLD_DATADIR=`select @@datadir`;
|
||||||
|
|
||||||
let bugdir= $MYSQLTEST_VARDIR/tmp/table_flags;
|
let bugdir= $MYSQLTEST_VARDIR/tmp/table_flags;
|
||||||
--mkdir $bugdir
|
--mkdir $bugdir
|
||||||
|
let undodir= $MYSQLTEST_VARDIR/tmp/undo_dir;
|
||||||
|
--mkdir $undodir
|
||||||
|
|
||||||
--let SEARCH_FILE = $MYSQLTEST_VARDIR/log/mysqld.1.err
|
--let SEARCH_FILE = $MYSQLTEST_VARDIR/log/mysqld.1.err
|
||||||
|
|
||||||
--let $d=--innodb-data-home-dir=$bugdir --innodb-log-group-home-dir=$bugdir
|
--let $d=--innodb-data-home-dir=$bugdir --innodb-log-group-home-dir=$bugdir
|
||||||
--let $d=$d --innodb-data-file-path=ibdata1:1M:autoextend
|
--let $d=$d --innodb-data-file-path=ibdata1:1M:autoextend
|
||||||
--let $d=$d --innodb-undo-tablespaces=0
|
--let $d=$d --innodb-undo-tablespaces=0
|
||||||
--let $d=$d --skip-innodb-fast-shutdown
|
--let $d=$d --skip-innodb-fast-shutdown --innodb_undo_directory=$undodir
|
||||||
--let $restart_noprint=1
|
--let $restart_noprint=1
|
||||||
--let $restart_parameters=$d --innodb-stats-persistent=0
|
--let $restart_parameters=$d --innodb-stats-persistent=0
|
||||||
--source include/restart_mysqld.inc
|
--source include/restart_mysqld.inc
|
||||||
|
@ -233,6 +236,7 @@ DROP TABLE tr,tc,td,tz,tp;
|
||||||
--list_files $bugdir
|
--list_files $bugdir
|
||||||
--remove_files_wildcard $bugdir
|
--remove_files_wildcard $bugdir
|
||||||
--rmdir $bugdir
|
--rmdir $bugdir
|
||||||
|
--rmdir $undodir
|
||||||
|
|
||||||
call mtr.add_suppression("ERROR HY000: Can't create table `test`.`t1`");
|
call mtr.add_suppression("ERROR HY000: Can't create table `test`.`t1`");
|
||||||
--error ER_CANT_CREATE_TABLE
|
--error ER_CANT_CREATE_TABLE
|
||||||
|
|
|
@ -76,3 +76,46 @@ SELECT @@global.innodb_undo_tablespaces;
|
||||||
|
|
||||||
--echo # Should list 2 undo log tablespaces, not 4
|
--echo # Should list 2 undo log tablespaces, not 4
|
||||||
list_files $MYSQLD_DATADIR undo*;
|
list_files $MYSQLD_DATADIR undo*;
|
||||||
|
|
||||||
|
--echo #
|
||||||
|
--echo # MDEV-34200 InnoDB tries to write to read-only
|
||||||
|
--echo # system tablespace in buf_dblwr_t::init_or_load_pages()
|
||||||
|
--echo #
|
||||||
|
|
||||||
|
SET GLOBAL innodb_fast_shutdown=0;
|
||||||
|
let $restart_parameters=--innodb_undo_tablespaces=4;
|
||||||
|
--source include/restart_mysqld.inc
|
||||||
|
--echo # Should list 4 undo log tablespaces
|
||||||
|
list_files $MYSQLD_DATADIR undo*;
|
||||||
|
|
||||||
|
set global innodb_fast_shutdown=0;
|
||||||
|
let $restart_parameters=--innodb_read_only=1;
|
||||||
|
--source include/restart_mysqld.inc
|
||||||
|
|
||||||
|
set global innodb_fast_shutdown=0;
|
||||||
|
let bugdir= $MYSQLTEST_VARDIR/tmp/bugdir;
|
||||||
|
mkdir $bugdir;
|
||||||
|
let undodir= $MYSQLTEST_VARDIR/tmp/undo_dir;
|
||||||
|
mkdir $undodir;
|
||||||
|
let $d= --innodb-data-file-path=ibdata1:1M:autoextend;
|
||||||
|
let $d=$d --innodb_undo_directory=$undodir;
|
||||||
|
let $restart_parameters= $d --innodb-data-home-dir=$bugdir --innodb-log-group-home-dir=$bugdir --innodb_undo_tablespaces=3;
|
||||||
|
--source include/restart_mysqld.inc
|
||||||
|
--echo # Should list 3 undo log tablespaces
|
||||||
|
list_files $undodir undo*;
|
||||||
|
|
||||||
|
let bugdir_1= $MYSQLTEST_VARDIR/tmp/bugdir_1;
|
||||||
|
mkdir $bugdir_1;
|
||||||
|
|
||||||
|
set global innodb_fast_shutdown=0;
|
||||||
|
let $restart_parameters= $d --innodb-data-home-dir=$bugdir_1 --innodb-log-group-home-dir=$bugdir_1 --innodb_undo_tablespaces=0;
|
||||||
|
--source include/restart_mysqld.inc
|
||||||
|
--echo # Shouldn't list 0 undo log tablespaces
|
||||||
|
list_files $undodir undo*;
|
||||||
|
|
||||||
|
set global innodb_fast_shutdown=0;
|
||||||
|
let $restart_parameters=;
|
||||||
|
--source include/restart_mysqld.inc
|
||||||
|
rmdir $bugdir;
|
||||||
|
rmdir $bugdir_1;
|
||||||
|
rmdir $undodir;
|
||||||
|
|
|
@ -1381,6 +1381,12 @@ bool Item_func_sformat::fix_length_and_dec(THD *thd)
|
||||||
*/
|
*/
|
||||||
namespace fmt {
|
namespace fmt {
|
||||||
template <> struct formatter<String>: formatter<string_view> {
|
template <> struct formatter<String>: formatter<string_view> {
|
||||||
|
template <typename FormatContext>
|
||||||
|
auto format(String c, FormatContext& ctx) const -> decltype(ctx.out()) {
|
||||||
|
string_view name = { c.ptr(), c.length() };
|
||||||
|
return formatter<string_view>::format(name, ctx);
|
||||||
|
};
|
||||||
|
/* needed below function for libfmt-7.1.3 compatibility, (not 9.1.0+) */
|
||||||
template <typename FormatContext>
|
template <typename FormatContext>
|
||||||
auto format(String c, FormatContext& ctx) -> decltype(ctx.out()) {
|
auto format(String c, FormatContext& ctx) -> decltype(ctx.out()) {
|
||||||
string_view name = { c.ptr(), c.length() };
|
string_view name = { c.ptr(), c.length() };
|
||||||
|
|
|
@ -284,6 +284,7 @@ func_exit:
|
||||||
init(TRX_SYS_DOUBLEWRITE + read_buf);
|
init(TRX_SYS_DOUBLEWRITE + read_buf);
|
||||||
|
|
||||||
const bool upgrade_to_innodb_file_per_table=
|
const bool upgrade_to_innodb_file_per_table=
|
||||||
|
!srv_read_only_mode &&
|
||||||
mach_read_from_4(TRX_SYS_DOUBLEWRITE_SPACE_ID_STORED +
|
mach_read_from_4(TRX_SYS_DOUBLEWRITE_SPACE_ID_STORED +
|
||||||
TRX_SYS_DOUBLEWRITE + read_buf) !=
|
TRX_SYS_DOUBLEWRITE + read_buf) !=
|
||||||
TRX_SYS_DOUBLEWRITE_SPACE_ID_STORED_N;
|
TRX_SYS_DOUBLEWRITE_SPACE_ID_STORED_N;
|
||||||
|
|
|
@ -369,6 +369,11 @@ inline dberr_t trx_sys_t::reset_page(mtr_t *mtr)
|
||||||
sys_header->page.frame + TRX_SYS_DOUBLEWRITE
|
sys_header->page.frame + TRX_SYS_DOUBLEWRITE
|
||||||
+ FSEG_HEADER_SIZE + TRX_SYS_DOUBLEWRITE_REPEAT,
|
+ FSEG_HEADER_SIZE + TRX_SYS_DOUBLEWRITE_REPEAT,
|
||||||
sys_header->page.frame + TRX_SYS_DOUBLEWRITE + FSEG_HEADER_SIZE, 12);
|
sys_header->page.frame + TRX_SYS_DOUBLEWRITE + FSEG_HEADER_SIZE, 12);
|
||||||
|
mtr->write<4>(
|
||||||
|
*sys_header,
|
||||||
|
TRX_SYS_DOUBLEWRITE + TRX_SYS_DOUBLEWRITE_SPACE_ID_STORED +
|
||||||
|
sys_header->page.frame,
|
||||||
|
TRX_SYS_DOUBLEWRITE_SPACE_ID_STORED_N);
|
||||||
}
|
}
|
||||||
|
|
||||||
return DB_SUCCESS;
|
return DB_SUCCESS;
|
||||||
|
@ -822,7 +827,7 @@ unused_undo:
|
||||||
{
|
{
|
||||||
char name[OS_FILE_MAX_PATH];
|
char name[OS_FILE_MAX_PATH];
|
||||||
snprintf(name, sizeof name, "%s/undo%03u", srv_undo_dir, i);
|
snprintf(name, sizeof name, "%s/undo%03u", srv_undo_dir, i);
|
||||||
uint32_t space_id= srv_undo_tablespace_open(create_new_undo, name, i);
|
uint32_t space_id= srv_undo_tablespace_open(false, name, i);
|
||||||
if (!space_id || space_id == ~0U)
|
if (!space_id || space_id == ~0U)
|
||||||
break;
|
break;
|
||||||
if (0 == srv_undo_tablespaces_open++)
|
if (0 == srv_undo_tablespaces_open++)
|
||||||
|
|
Loading…
Add table
Reference in a new issue