Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
M
MariaDB
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
nexedi
MariaDB
Commits
96a3b11d
Commit
96a3b11d
authored
Feb 14, 2023
by
Marko Mäkelä
Browse files
Options
Browse Files
Download
Plain Diff
Merge 10.5 into 10.6
parents
6aec8754
1a5c7552
Changes
10
Show whitespace changes
Inline
Side-by-side
Showing
10 changed files
with
111 additions
and
8 deletions
+111
-8
mysql-test/main/func_json.result
mysql-test/main/func_json.result
+16
-1
mysql-test/main/func_json.test
mysql-test/main/func_json.test
+13
-3
mysql-test/suite/innodb/r/alter_copy.result
mysql-test/suite/innodb/r/alter_copy.result
+1
-1
mysql-test/suite/innodb/r/recovery_memory.result
mysql-test/suite/innodb/r/recovery_memory.result
+20
-0
mysql-test/suite/innodb/t/alter_copy.test
mysql-test/suite/innodb/t/alter_copy.test
+1
-1
mysql-test/suite/innodb/t/recovery_memory.test
mysql-test/suite/innodb/t/recovery_memory.test
+21
-0
sql/item_jsonfunc.cc
sql/item_jsonfunc.cc
+1
-1
storage/innobase/buf/buf0lru.cc
storage/innobase/buf/buf0lru.cc
+8
-1
storage/innobase/ibuf/ibuf0ibuf.cc
storage/innobase/ibuf/ibuf0ibuf.cc
+4
-0
storage/innobase/log/log0recv.cc
storage/innobase/log/log0recv.cc
+26
-0
No files found.
mysql-test/main/func_json.result
View file @
96a3b11d
...
@@ -1623,6 +1623,21 @@ id doc
...
@@ -1623,6 +1623,21 @@ id doc
{"$oid":"611c0a463b150154132f6636"} { "_id" : { "$oid" : "611c0a463b150154132f6636" }, "a" : [ { "a" : [ { "a" : [ { "a" : [ { "a" : [ { "a" : [ { "a" : [ { "a" : [ { "a" : [ { "a" : [ { "a" : [ { "a" : [ { "a" : [ { "a" : [ { "a" : [ { "a" : 1.0 } ] } ] } ] } ] } ] } ] } ] } ] } ] } ] } ] } ] } ] } ] } ] }
{"$oid":"611c0a463b150154132f6636"} { "_id" : { "$oid" : "611c0a463b150154132f6636" }, "a" : [ { "a" : [ { "a" : [ { "a" : [ { "a" : [ { "a" : [ { "a" : [ { "a" : [ { "a" : [ { "a" : [ { "a" : [ { "a" : [ { "a" : [ { "a" : [ { "a" : [ { "a" : 1.0 } ] } ] } ] } ] } ] } ] } ] } ] } ] } ] } ] } ] } ] } ] } ] }
DROP TABLE arrNestTest;
DROP TABLE arrNestTest;
#
#
# MDEV-30412 JSON_OBJECTAGG doesn't escape double quote in key
#
SELECT JSON_OBJECTAGG('"', 1);
JSON_OBJECTAGG('"', 1)
{"\"":1}
SELECT JSON_OBJECTAGG('\"', 1);
JSON_OBJECTAGG('\"', 1)
{"\"":1}
SELECT JSON_OBJECTAGG('\\', 1);
JSON_OBJECTAGG('\\', 1)
{"\\":1}
#
# End of 10.5 tests
#
#
# MDEV-26054 Server crashes in Item_func_json_arrayagg::get_str_from_field
# MDEV-26054 Server crashes in Item_func_json_arrayagg::get_str_from_field
#
#
CREATE TABLE t (a VARCHAR(8));
CREATE TABLE t (a VARCHAR(8));
...
@@ -1649,5 +1664,5 @@ JSON_INSERT(JSON_OBJECT(l1, l2, l3, l4), '$.k3', 'v3') JSON_SET(JSON_OBJECT(l1,
...
@@ -1649,5 +1664,5 @@ JSON_INSERT(JSON_OBJECT(l1, l2, l3, l4), '$.k3', 'v3') JSON_SET(JSON_OBJECT(l1,
{"k1": "v1", "k2": "v2", "k3": "v3"} {"k1": "v1", "k2": "new v2"} {"k1": "v1", "k2": "new v2"}
{"k1": "v1", "k2": "v2", "k3": "v3"} {"k1": "v1", "k2": "new v2"} {"k1": "v1", "k2": "new v2"}
DROP TABLE t;
DROP TABLE t;
#
#
# End of 10.
5
tests
# End of 10.
6
tests
#
#
mysql-test/main/func_json.test
View file @
96a3b11d
...
@@ -1067,6 +1067,18 @@ INSERT INTO test.arrNestTest (doc) VALUES ('{ "_id" : { "$oid" : "611c0a463b1501
...
@@ -1067,6 +1067,18 @@ INSERT INTO test.arrNestTest (doc) VALUES ('{ "_id" : { "$oid" : "611c0a463b1501
SELECT
*
FROM
arrNestTest
;
SELECT
*
FROM
arrNestTest
;
DROP
TABLE
arrNestTest
;
DROP
TABLE
arrNestTest
;
--
echo
#
--
echo
# MDEV-30412 JSON_OBJECTAGG doesn't escape double quote in key
--
echo
#
SELECT
JSON_OBJECTAGG
(
'"'
,
1
);
SELECT
JSON_OBJECTAGG
(
'\"'
,
1
);
SELECT
JSON_OBJECTAGG
(
'\\'
,
1
);
--
echo
#
--
echo
# End of 10.5 tests
--
echo
#
--
echo
#
--
echo
#
--
echo
# MDEV-26054 Server crashes in Item_func_json_arrayagg::get_str_from_field
--
echo
# MDEV-26054 Server crashes in Item_func_json_arrayagg::get_str_from_field
--
echo
#
--
echo
#
...
@@ -1078,7 +1090,6 @@ SELECT JSON_ARRAYAGG(a) AS f FROM v;
...
@@ -1078,7 +1090,6 @@ SELECT JSON_ARRAYAGG(a) AS f FROM v;
DROP
VIEW
v
;
DROP
VIEW
v
;
DROP
TABLE
t
;
DROP
TABLE
t
;
--
echo
#
--
echo
#
--
echo
# MDEV-29264 JSON functions overflow error based ON LONGTEXT field
--
echo
# MDEV-29264 JSON functions overflow error based ON LONGTEXT field
--
echo
#
--
echo
#
...
@@ -1090,6 +1101,5 @@ SELECT JSON_INSERT(JSON_OBJECT(l1, l2, l3, l4), '$.k3', 'v3'),JSON_SET(JSON_OBJE
...
@@ -1090,6 +1101,5 @@ SELECT JSON_INSERT(JSON_OBJECT(l1, l2, l3, l4), '$.k3', 'v3'),JSON_SET(JSON_OBJE
DROP
TABLE
t
;
DROP
TABLE
t
;
--
echo
#
--
echo
#
--
echo
# End of 10.
5
tests
--
echo
# End of 10.
6
tests
--
echo
#
--
echo
#
mysql-test/suite/innodb/r/alter_copy.result
View file @
96a3b11d
...
@@ -51,7 +51,7 @@ ADD INDEX(a,b,d), ADD INDEX(a,d,b), ADD INDEX(b,c,d), ADD INDEX(b,d,c),
...
@@ -51,7 +51,7 @@ ADD INDEX(a,b,d), ADD INDEX(a,d,b), ADD INDEX(b,c,d), ADD INDEX(b,d,c),
ALGORITHM=COPY;
ALGORITHM=COPY;
connection default;
connection default;
SET DEBUG_SYNC='now WAIT_FOR hung';
SET DEBUG_SYNC='now WAIT_FOR hung';
# restart: --innodb-force-recovery=3
# restart: --innodb-force-recovery=3
--debug_dbug=+d,recv_ran_out_of_buffer
disconnect hang;
disconnect hang;
FTS_INDEX_1.ibd
FTS_INDEX_1.ibd
FTS_INDEX_2.ibd
FTS_INDEX_2.ibd
...
...
mysql-test/suite/innodb/r/recovery_memory.result
View file @
96a3b11d
call mtr.add_suppression("InnoDB: The change buffer is corrupted");
call mtr.add_suppression("InnoDB: Plugin initialization aborted at srv0start.cc");
call mtr.add_suppression("Plugin 'InnoDB' init function returned error");
call mtr.add_suppression("Plugin 'InnoDB' registration as a STORAGE ENGINE failed.");
CREATE TABLE t1(c TEXT, KEY(c(3072)))ENGINE=InnoDB;
CREATE TABLE t1(c TEXT, KEY(c(3072)))ENGINE=InnoDB;
CREATE PROCEDURE dorepeat()
CREATE PROCEDURE dorepeat()
LOOP
LOOP
...
@@ -10,3 +14,19 @@ CALL dorepeat();
...
@@ -10,3 +14,19 @@ CALL dorepeat();
connection default;
connection default;
# restart: --innodb_buffer_pool_size=5242880
# restart: --innodb_buffer_pool_size=5242880
DROP TABLE t1;
DROP TABLE t1;
DROP PROCEDURE dorepeat;
#
# MDEV-30552 InnoDB recovery crashes when error
# handling scenario
#
SET DEBUG_DBUG="+d,ib_log_checkpoint_avoid_hard";
CREATE TABLE t1(f1 INT NOT NULL)ENGINE=InnoDB;
INSERT INTO t1 SELECT * FROM seq_1_to_65536;
# restart: --innodb_buffer_pool_size=5242880 --debug_dbug=+d,ibuf_init_corrupt
# restart
SHOW CREATE TABLE t1;
Table Create Table
t1 CREATE TABLE `t1` (
`f1` int(11) NOT NULL
) ENGINE=InnoDB DEFAULT CHARSET=latin1 COLLATE=latin1_swedish_ci
DROP TABLE t1;
mysql-test/suite/innodb/t/alter_copy.test
View file @
96a3b11d
...
@@ -57,7 +57,7 @@ ALTER TABLE t ADD INDEX(b,c,d,a),ADD INDEX(b,c,a,d),ADD INDEX(b,a,c,d),ADD INDEX
...
@@ -57,7 +57,7 @@ ALTER TABLE t ADD INDEX(b,c,d,a),ADD INDEX(b,c,a,d),ADD INDEX(b,a,c,d),ADD INDEX
connection
default
;
connection
default
;
SET
DEBUG_SYNC
=
'now WAIT_FOR hung'
;
SET
DEBUG_SYNC
=
'now WAIT_FOR hung'
;
let
$shutdown_timeout
=
0
;
let
$shutdown_timeout
=
0
;
--
let
$restart_parameters
=
--
innodb
-
force
-
recovery
=
3
--
let
$restart_parameters
=
--
innodb
-
force
-
recovery
=
3
--
debug_dbug
=
"+d,recv_ran_out_of_buffer"
--
source
include
/
restart_mysqld
.
inc
--
source
include
/
restart_mysqld
.
inc
disconnect
hang
;
disconnect
hang
;
let
$shutdown_timeout
=
;
let
$shutdown_timeout
=
;
...
...
mysql-test/suite/innodb/t/recovery_memory.test
View file @
96a3b11d
--
source
include
/
have_innodb
.
inc
--
source
include
/
have_innodb
.
inc
--
source
include
/
big_test
.
inc
--
source
include
/
big_test
.
inc
--
source
include
/
have_sequence
.
inc
call
mtr
.
add_suppression
(
"InnoDB: The change buffer is corrupted"
);
call
mtr
.
add_suppression
(
"InnoDB: Plugin initialization aborted at srv0start.cc"
);
call
mtr
.
add_suppression
(
"Plugin 'InnoDB' init function returned error"
);
call
mtr
.
add_suppression
(
"Plugin 'InnoDB' registration as a STORAGE ENGINE failed."
);
CREATE
TABLE
t1
(
c
TEXT
,
KEY
(
c
(
3072
)))
ENGINE
=
InnoDB
;
CREATE
TABLE
t1
(
c
TEXT
,
KEY
(
c
(
3072
)))
ENGINE
=
InnoDB
;
DELIMITER
|
;
DELIMITER
|
;
...
@@ -19,3 +24,19 @@ let $shutdown_timeout=0;
...
@@ -19,3 +24,19 @@ let $shutdown_timeout=0;
let
$restart_parameters
=--
innodb_buffer_pool_size
=
5242880
;
let
$restart_parameters
=--
innodb_buffer_pool_size
=
5242880
;
--
source
include
/
restart_mysqld
.
inc
--
source
include
/
restart_mysqld
.
inc
DROP
TABLE
t1
;
DROP
TABLE
t1
;
DROP
PROCEDURE
dorepeat
;
--
echo
#
--
echo
# MDEV-30552 InnoDB recovery crashes when error
--
echo
# handling scenario
--
echo
#
SET
DEBUG_DBUG
=
"+d,ib_log_checkpoint_avoid_hard"
;
CREATE
TABLE
t1
(
f1
INT
NOT
NULL
)
ENGINE
=
InnoDB
;
INSERT
INTO
t1
SELECT
*
FROM
seq_1_to_65536
;
let
$shutdown_timeout
=
0
;
let
$restart_parameters
=--
innodb_buffer_pool_size
=
5242880
--
debug_dbug
=
"+d,ibuf_init_corrupt"
;
--
source
include
/
restart_mysqld
.
inc
let
$restart_parameters
=
;
--
source
include
/
restart_mysqld
.
inc
SHOW
CREATE
TABLE
t1
;
DROP
TABLE
t1
;
sql/item_jsonfunc.cc
View file @
96a3b11d
...
@@ -4083,7 +4083,7 @@ bool Item_func_json_objectagg::add()
...
@@ -4083,7 +4083,7 @@ bool Item_func_json_objectagg::add()
result
.
append
(
STRING_WITH_LEN
(
", "
));
result
.
append
(
STRING_WITH_LEN
(
", "
));
result
.
append
(
'"'
);
result
.
append
(
'"'
);
result
.
append
(
*
key
);
st_append_escaped
(
&
result
,
key
);
result
.
append
(
STRING_WITH_LEN
(
"
\"
:"
));
result
.
append
(
STRING_WITH_LEN
(
"
\"
:"
));
buf
.
length
(
0
);
buf
.
length
(
0
);
...
...
storage/innobase/buf/buf0lru.cc
View file @
96a3b11d
...
@@ -397,6 +397,11 @@ buf_block_t *buf_LRU_get_free_block(bool have_mutex)
...
@@ -397,6 +397,11 @@ buf_block_t *buf_LRU_get_free_block(bool have_mutex)
mysql_mutex_assert_owner
(
&
buf_pool
.
mutex
);
mysql_mutex_assert_owner
(
&
buf_pool
.
mutex
);
goto
got_mutex
;
goto
got_mutex
;
}
}
DBUG_EXECUTE_IF
(
"recv_ran_out_of_buffer"
,
if
(
recv_recovery_is_on
()
&&
recv_sys
.
apply_log_recs
)
{
goto
flush_lru
;
});
mysql_mutex_lock
(
&
buf_pool
.
mutex
);
mysql_mutex_lock
(
&
buf_pool
.
mutex
);
got_mutex:
got_mutex:
buf_LRU_check_size_of_non_data_objects
();
buf_LRU_check_size_of_non_data_objects
();
...
@@ -482,7 +487,9 @@ buf_block_t *buf_LRU_get_free_block(bool have_mutex)
...
@@ -482,7 +487,9 @@ buf_block_t *buf_LRU_get_free_block(bool have_mutex)
removing the block from buf_pool.page_hash and buf_pool.LRU is fairly
removing the block from buf_pool.page_hash and buf_pool.LRU is fairly
involved (particularly in case of ROW_FORMAT=COMPRESSED pages). We
involved (particularly in case of ROW_FORMAT=COMPRESSED pages). We
can do that in a separate patch sometime in future. */
can do that in a separate patch sometime in future. */
#ifndef DBUG_OFF
flush_lru:
#endif
if
(
!
buf_flush_LRU
(
innodb_lru_flush_size
))
{
if
(
!
buf_flush_LRU
(
innodb_lru_flush_size
))
{
MONITOR_INC
(
MONITOR_LRU_SINGLE_FLUSH_FAILURE_COUNT
);
MONITOR_INC
(
MONITOR_LRU_SINGLE_FLUSH_FAILURE_COUNT
);
++
flush_failures
;
++
flush_failures
;
...
...
storage/innobase/ibuf/ibuf0ibuf.cc
View file @
96a3b11d
...
@@ -426,6 +426,10 @@ ibuf_init_at_db_start(void)
...
@@ -426,6 +426,10 @@ ibuf_init_at_db_start(void)
goto
err_exit
;
goto
err_exit
;
}
}
DBUG_EXECUTE_IF
(
"ibuf_init_corrupt"
,
err
=
DB_CORRUPTION
;
goto
err_exit
;);
if
(
page_is_comp
(
root
)
||
fil_page_get_type
(
root
)
!=
FIL_PAGE_INDEX
if
(
page_is_comp
(
root
)
||
fil_page_get_type
(
root
)
!=
FIL_PAGE_INDEX
||
btr_page_get_index_id
(
root
)
!=
DICT_IBUF_ID_MIN
)
{
||
btr_page_get_index_id
(
root
)
!=
DICT_IBUF_ID_MIN
)
{
err
=
DB_CORRUPTION
;
err
=
DB_CORRUPTION
;
...
...
storage/innobase/log/log0recv.cc
View file @
96a3b11d
...
@@ -747,8 +747,10 @@ static struct
...
@@ -747,8 +747,10 @@ static struct
bool
reinit_all
()
bool
reinit_all
()
{
{
retry:
retry:
mysql_mutex_unlock
(
&
log_sys
.
mutex
);
bool
fail
=
false
;
bool
fail
=
false
;
buf_block_t
*
free_block
=
buf_LRU_get_free_block
(
false
);
buf_block_t
*
free_block
=
buf_LRU_get_free_block
(
false
);
mysql_mutex_lock
(
&
log_sys
.
mutex
);
mysql_mutex_lock
(
&
recv_sys
.
mutex
);
mysql_mutex_lock
(
&
recv_sys
.
mutex
);
for
(
auto
d
=
defers
.
begin
();
d
!=
defers
.
end
();
)
for
(
auto
d
=
defers
.
begin
();
d
!=
defers
.
end
();
)
...
@@ -3287,8 +3289,22 @@ void recv_sys_t::apply(bool last_batch)
...
@@ -3287,8 +3289,22 @@ void recv_sys_t::apply(bool last_batch)
fil_system
.
extend_to_recv_size
();
fil_system
.
extend_to_recv_size
();
/* We must release log_sys.mutex and recv_sys.mutex before
invoking buf_LRU_get_free_block(). Allocating a block may initiate
a redo log write and therefore acquire log_sys.mutex. To avoid
deadlocks, log_sys.mutex must not be acquired while holding
recv_sys.mutex. */
mysql_mutex_unlock
(
&
mutex
);
if
(
!
last_batch
)
mysql_mutex_unlock
(
&
log_sys
.
mutex
);
mysql_mutex_assert_not_owner
(
&
log_sys
.
mutex
);
buf_block_t
*
free_block
=
buf_LRU_get_free_block
(
false
);
buf_block_t
*
free_block
=
buf_LRU_get_free_block
(
false
);
if
(
!
last_batch
)
mysql_mutex_lock
(
&
log_sys
.
mutex
);
mysql_mutex_lock
(
&
mutex
);
for
(
map
::
iterator
p
=
pages
.
begin
();
p
!=
pages
.
end
();
)
for
(
map
::
iterator
p
=
pages
.
begin
();
p
!=
pages
.
end
();
)
{
{
const
page_id_t
page_id
=
p
->
first
;
const
page_id_t
page_id
=
p
->
first
;
...
@@ -3334,7 +3350,12 @@ void recv_sys_t::apply(bool last_batch)
...
@@ -3334,7 +3350,12 @@ void recv_sys_t::apply(bool last_batch)
{
{
next_free_block:
next_free_block:
mysql_mutex_unlock
(
&
mutex
);
mysql_mutex_unlock
(
&
mutex
);
if
(
!
last_batch
)
mysql_mutex_unlock
(
&
log_sys
.
mutex
);
mysql_mutex_assert_not_owner
(
&
log_sys
.
mutex
);
free_block
=
buf_LRU_get_free_block
(
false
);
free_block
=
buf_LRU_get_free_block
(
false
);
if
(
!
last_batch
)
mysql_mutex_lock
(
&
log_sys
.
mutex
);
mysql_mutex_lock
(
&
mutex
);
mysql_mutex_lock
(
&
mutex
);
break
;
break
;
}
}
...
@@ -4305,6 +4326,11 @@ recv_recovery_from_checkpoint_start(lsn_t flush_lsn)
...
@@ -4305,6 +4326,11 @@ recv_recovery_from_checkpoint_start(lsn_t flush_lsn)
mysql_mutex_unlock
(
&
log_sys
.
mutex
);
mysql_mutex_unlock
(
&
log_sys
.
mutex
);
return
(
DB_ERROR
);
return
(
DB_ERROR
);
}
}
/* In case of multi-batch recovery,
redo log for the last batch is not
applied yet. */
ut_d
(
recv_sys
.
after_apply
=
false
);
}
}
}
else
{
}
else
{
ut_ad
(
!
rescan
||
recv_sys
.
pages
.
empty
());
ut_ad
(
!
rescan
||
recv_sys
.
pages
.
empty
());
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment