Browse Source
MDEV-7572: InnoDB: Assertion failure in log_init_crypt_key if
MDEV-7572: InnoDB: Assertion failure in log_init_crypt_key if
file_key_management_plugin is used Fixed error handling and added disabling InnoDB redo log encryption if encryption key management plugin is not there.pull/16/merge
8 changed files with 467 additions and 25 deletions
-
4include/my_aes.h
-
2include/mysql/plugin_encryption_key_management.h
-
239mysql-test/suite/innodb/r/innodb-page_encryption_log_encryption.result
-
2mysql-test/suite/innodb/t/innodb-page_encryption_log_encryption.opt
-
152mysql-test/suite/innodb/t/innodb-page_encryption_log_encryption.test
-
6sql/encryption_keys.cc
-
44storage/innobase/log/log0crypt.cc
-
43storage/xtradb/log/log0crypt.cc
@ -0,0 +1,239 @@ |
|||
call mtr.add_suppression("KeyID 0 not found or with error. Check the key and the log file*"); |
|||
call mtr.add_suppression("Disabling redo log encryption"); |
|||
SET GLOBAL innodb_file_format = `Barracuda`; |
|||
SET GLOBAL innodb_file_per_table = ON; |
|||
create table innodb_normal(c1 bigint not null, b char(200)) engine=innodb; |
|||
create table innodb_compact(c1 bigint not null, b char(200)) engine=innodb row_format=compact page_encryption=1 page_encryption_key=1; |
|||
create table innodb_compressed(c1 bigint not null, b char(200)) engine=innodb row_format=compressed page_encryption=1 page_encryption_key=2; |
|||
create table innodb_dynamic(c1 bigint not null, b char(200)) engine=innodb row_format=dynamic page_encryption=1 page_encryption_key=3; |
|||
create table innodb_redundant(c1 bigint not null, b char(200)) engine=innodb row_format=redundant page_encryption=1 page_encryption_key=4; |
|||
show create table innodb_compact; |
|||
Table Create Table |
|||
innodb_compact CREATE TABLE `innodb_compact` ( |
|||
`c1` bigint(20) NOT NULL, |
|||
`b` char(200) DEFAULT NULL |
|||
) ENGINE=InnoDB DEFAULT CHARSET=latin1 ROW_FORMAT=COMPACT `page_encryption`=1 `page_encryption_key`=1 |
|||
show create table innodb_compressed; |
|||
Table Create Table |
|||
innodb_compressed CREATE TABLE `innodb_compressed` ( |
|||
`c1` bigint(20) NOT NULL, |
|||
`b` char(200) DEFAULT NULL |
|||
) ENGINE=InnoDB DEFAULT CHARSET=latin1 ROW_FORMAT=COMPRESSED `page_encryption`=1 `page_encryption_key`=2 |
|||
show create table innodb_dynamic; |
|||
Table Create Table |
|||
innodb_dynamic CREATE TABLE `innodb_dynamic` ( |
|||
`c1` bigint(20) NOT NULL, |
|||
`b` char(200) DEFAULT NULL |
|||
) ENGINE=InnoDB DEFAULT CHARSET=latin1 ROW_FORMAT=DYNAMIC `page_encryption`=1 `page_encryption_key`=3 |
|||
show create table innodb_redundant; |
|||
Table Create Table |
|||
innodb_redundant CREATE TABLE `innodb_redundant` ( |
|||
`c1` bigint(20) NOT NULL, |
|||
`b` char(200) DEFAULT NULL |
|||
) ENGINE=InnoDB DEFAULT CHARSET=latin1 ROW_FORMAT=REDUNDANT `page_encryption`=1 `page_encryption_key`=4 |
|||
create procedure innodb_insert_proc (repeat_count int) |
|||
begin |
|||
declare current_num int; |
|||
set current_num = 0; |
|||
while current_num < repeat_count do |
|||
insert into innodb_normal values(current_num, substring(MD5(RAND()), -64)); |
|||
set current_num = current_num + 1; |
|||
end while; |
|||
end// |
|||
commit; |
|||
set autocommit=0; |
|||
call innodb_insert_proc(2000); |
|||
commit; |
|||
set autocommit=1; |
|||
insert into innodb_compact select * from innodb_normal; |
|||
insert into innodb_compressed select * from innodb_normal; |
|||
insert into innodb_dynamic select * from innodb_normal; |
|||
insert into innodb_redundant select * from innodb_normal; |
|||
update innodb_normal set c1 = c1 +1; |
|||
update innodb_compact set c1 = c1 + 1; |
|||
update innodb_compressed set c1 = c1 + 1; |
|||
update innodb_dynamic set c1 = c1 + 1; |
|||
update innodb_redundant set c1 = c1 + 1; |
|||
select count(*) from innodb_compact where c1 < 1500000; |
|||
count(*) |
|||
2000 |
|||
select count(*) from innodb_compressed where c1 < 1500000; |
|||
count(*) |
|||
2000 |
|||
select count(*) from innodb_dynamic where c1 < 1500000; |
|||
count(*) |
|||
2000 |
|||
select count(*) from innodb_redundant where c1 < 1500000; |
|||
count(*) |
|||
2000 |
|||
select count(*) from innodb_compact t1, innodb_normal t2 where |
|||
t1.c1 = t2.c1 and t1.b = t2.b; |
|||
count(*) |
|||
2000 |
|||
select count(*) from innodb_dynamic t1, innodb_normal t2 where |
|||
t1.c1 = t2.c1 and t1.b = t2.b; |
|||
count(*) |
|||
2000 |
|||
select count(*) from innodb_compressed t1, innodb_normal t2 where |
|||
t1.c1 = t2.c1 and t1.b = t2.b; |
|||
count(*) |
|||
2000 |
|||
select count(*) from innodb_redundant t1, innodb_normal t2 where |
|||
t1.c1 = t2.c1 and t1.b = t2.b; |
|||
count(*) |
|||
2000 |
|||
SELECT variable_value >= 0 FROM information_schema.global_status WHERE LOWER(variable_name) = 'innodb_num_pages_page_encrypted'; |
|||
variable_value >= 0 |
|||
1 |
|||
SELECT variable_value >= 0 FROM information_schema.global_status WHERE LOWER(variable_name) = 'innodb_num_pages_page_decrypted'; |
|||
variable_value >= 0 |
|||
1 |
|||
SELECT variable_value = 0 FROM information_schema.global_status WHERE LOWER(variable_name) = 'innodb_num_pages_page_encryption_error'; |
|||
variable_value = 0 |
|||
1 |
|||
SET GLOBAL innodb_file_format = `Barracuda`; |
|||
SET GLOBAL innodb_file_per_table = ON; |
|||
update innodb_normal set c1 = c1 +1; |
|||
update innodb_compact set c1 = c1 + 1; |
|||
update innodb_compressed set c1 = c1 + 1; |
|||
update innodb_dynamic set c1 = c1 + 1; |
|||
update innodb_redundant set c1 = c1 + 1; |
|||
select count(*) from innodb_compact where c1 < 1500000; |
|||
count(*) |
|||
2000 |
|||
select count(*) from innodb_compressed where c1 < 1500000; |
|||
count(*) |
|||
2000 |
|||
select count(*) from innodb_dynamic where c1 < 1500000; |
|||
count(*) |
|||
2000 |
|||
select count(*) from innodb_redundant where c1 < 1500000; |
|||
count(*) |
|||
2000 |
|||
select count(*) from innodb_compact t1, innodb_normal t2 where |
|||
t1.c1 = t2.c1 and t1.b = t2.b; |
|||
count(*) |
|||
2000 |
|||
select count(*) from innodb_dynamic t1, innodb_normal t2 where |
|||
t1.c1 = t2.c1 and t1.b = t2.b; |
|||
count(*) |
|||
2000 |
|||
select count(*) from innodb_compressed t1, innodb_normal t2 where |
|||
t1.c1 = t2.c1 and t1.b = t2.b; |
|||
count(*) |
|||
2000 |
|||
select count(*) from innodb_redundant t1, innodb_normal t2 where |
|||
t1.c1 = t2.c1 and t1.b = t2.b; |
|||
count(*) |
|||
2000 |
|||
SELECT variable_value >= 0 FROM information_schema.global_status WHERE LOWER(variable_name) = 'innodb_num_pages_page_encrypted'; |
|||
variable_value >= 0 |
|||
1 |
|||
SELECT variable_value >= 0 FROM information_schema.global_status WHERE LOWER(variable_name) = 'innodb_num_pages_page_decrypted'; |
|||
variable_value >= 0 |
|||
1 |
|||
SELECT variable_value = 0 FROM information_schema.global_status WHERE LOWER(variable_name) = 'innodb_num_pages_page_encryption_error'; |
|||
variable_value = 0 |
|||
1 |
|||
alter table innodb_compact engine=innodb page_encryption=DEFAULT page_encryption_key=DEFAULT; |
|||
show create table innodb_compact; |
|||
Table Create Table |
|||
innodb_compact CREATE TABLE `innodb_compact` ( |
|||
`c1` bigint(20) NOT NULL, |
|||
`b` char(200) DEFAULT NULL |
|||
) ENGINE=InnoDB DEFAULT CHARSET=latin1 ROW_FORMAT=COMPACT |
|||
alter table innodb_compressed engine=innodb page_encryption=DEFAULT page_encryption_key=DEFAULT; |
|||
show create table innodb_compressed; |
|||
Table Create Table |
|||
innodb_compressed CREATE TABLE `innodb_compressed` ( |
|||
`c1` bigint(20) NOT NULL, |
|||
`b` char(200) DEFAULT NULL |
|||
) ENGINE=InnoDB DEFAULT CHARSET=latin1 ROW_FORMAT=COMPRESSED |
|||
alter table innodb_dynamic engine=innodb page_encryption=DEFAULT page_encryption_key=DEFAULT; |
|||
show create table innodb_dynamic; |
|||
Table Create Table |
|||
innodb_dynamic CREATE TABLE `innodb_dynamic` ( |
|||
`c1` bigint(20) NOT NULL, |
|||
`b` char(200) DEFAULT NULL |
|||
) ENGINE=InnoDB DEFAULT CHARSET=latin1 ROW_FORMAT=DYNAMIC |
|||
alter table innodb_redundant engine=innodb page_encryption=DEFAULT page_encryption_key=DEFAULT; |
|||
show create table innodb_redundant; |
|||
Table Create Table |
|||
innodb_redundant CREATE TABLE `innodb_redundant` ( |
|||
`c1` bigint(20) NOT NULL, |
|||
`b` char(200) DEFAULT NULL |
|||
) ENGINE=InnoDB DEFAULT CHARSET=latin1 ROW_FORMAT=REDUNDANT |
|||
SET GLOBAL innodb_file_format = `Barracuda`; |
|||
SET GLOBAL innodb_file_per_table = ON; |
|||
show create table innodb_compact; |
|||
Table Create Table |
|||
innodb_compact CREATE TABLE `innodb_compact` ( |
|||
`c1` bigint(20) NOT NULL, |
|||
`b` char(200) DEFAULT NULL |
|||
) ENGINE=InnoDB DEFAULT CHARSET=latin1 ROW_FORMAT=COMPACT |
|||
show create table innodb_compressed; |
|||
Table Create Table |
|||
innodb_compressed CREATE TABLE `innodb_compressed` ( |
|||
`c1` bigint(20) NOT NULL, |
|||
`b` char(200) DEFAULT NULL |
|||
) ENGINE=InnoDB DEFAULT CHARSET=latin1 ROW_FORMAT=COMPRESSED |
|||
show create table innodb_dynamic; |
|||
Table Create Table |
|||
innodb_dynamic CREATE TABLE `innodb_dynamic` ( |
|||
`c1` bigint(20) NOT NULL, |
|||
`b` char(200) DEFAULT NULL |
|||
) ENGINE=InnoDB DEFAULT CHARSET=latin1 ROW_FORMAT=DYNAMIC |
|||
show create table innodb_redundant; |
|||
Table Create Table |
|||
innodb_redundant CREATE TABLE `innodb_redundant` ( |
|||
`c1` bigint(20) NOT NULL, |
|||
`b` char(200) DEFAULT NULL |
|||
) ENGINE=InnoDB DEFAULT CHARSET=latin1 ROW_FORMAT=REDUNDANT |
|||
update innodb_normal set c1 = c1 +1; |
|||
update innodb_compact set c1 = c1 + 1; |
|||
update innodb_compressed set c1 = c1 + 1; |
|||
update innodb_dynamic set c1 = c1 + 1; |
|||
update innodb_redundant set c1 = c1 + 1; |
|||
select count(*) from innodb_compact where c1 < 1500000; |
|||
count(*) |
|||
2000 |
|||
select count(*) from innodb_compressed where c1 < 1500000; |
|||
count(*) |
|||
2000 |
|||
select count(*) from innodb_dynamic where c1 < 1500000; |
|||
count(*) |
|||
2000 |
|||
select count(*) from innodb_redundant where c1 < 1500000; |
|||
count(*) |
|||
2000 |
|||
select count(*) from innodb_compact t1, innodb_normal t2 where |
|||
t1.c1 = t2.c1 and t1.b = t2.b; |
|||
count(*) |
|||
2000 |
|||
select count(*) from innodb_dynamic t1, innodb_normal t2 where |
|||
t1.c1 = t2.c1 and t1.b = t2.b; |
|||
count(*) |
|||
2000 |
|||
select count(*) from innodb_compressed t1, innodb_normal t2 where |
|||
t1.c1 = t2.c1 and t1.b = t2.b; |
|||
count(*) |
|||
2000 |
|||
select count(*) from innodb_redundant t1, innodb_normal t2 where |
|||
t1.c1 = t2.c1 and t1.b = t2.b; |
|||
count(*) |
|||
2000 |
|||
SELECT variable_value = 0 FROM information_schema.global_status WHERE LOWER(variable_name) = 'innodb_num_pages_page_encrypted'; |
|||
variable_value = 0 |
|||
1 |
|||
SELECT variable_value = 0 FROM information_schema.global_status WHERE LOWER(variable_name) = 'innodb_num_pages_page_decrypted'; |
|||
variable_value = 0 |
|||
1 |
|||
SELECT variable_value = 0 FROM information_schema.global_status WHERE LOWER(variable_name) = 'innodb_num_pages_page_encryption_error'; |
|||
variable_value = 0 |
|||
1 |
|||
drop procedure innodb_insert_proc; |
|||
drop table innodb_normal; |
|||
drop table innodb_compact; |
|||
drop table innodb_compressed; |
|||
drop table innodb_dynamic; |
|||
drop table innodb_redundant; |
|||
@ -0,0 +1,2 @@ |
|||
--encryption-algorithm=aes_cbc |
|||
--innodb-encrypt-log |
|||
@ -0,0 +1,152 @@ |
|||
-- source include/have_innodb.inc |
|||
-- source include/have_file_key_management_plugin.inc |
|||
|
|||
--disable_query_log |
|||
let $innodb_file_format_orig = `SELECT @@innodb_file_format`; |
|||
let $innodb_file_per_table_orig = `SELECT @@innodb_file_per_table`; |
|||
--enable_query_log |
|||
|
|||
call mtr.add_suppression("KeyID 0 not found or with error. Check the key and the log file*"); |
|||
call mtr.add_suppression("Disabling redo log encryption"); |
|||
|
|||
SET GLOBAL innodb_file_format = `Barracuda`; |
|||
SET GLOBAL innodb_file_per_table = ON; |
|||
|
|||
create table innodb_normal(c1 bigint not null, b char(200)) engine=innodb; |
|||
create table innodb_compact(c1 bigint not null, b char(200)) engine=innodb row_format=compact page_encryption=1 page_encryption_key=1; |
|||
create table innodb_compressed(c1 bigint not null, b char(200)) engine=innodb row_format=compressed page_encryption=1 page_encryption_key=2; |
|||
create table innodb_dynamic(c1 bigint not null, b char(200)) engine=innodb row_format=dynamic page_encryption=1 page_encryption_key=3; |
|||
create table innodb_redundant(c1 bigint not null, b char(200)) engine=innodb row_format=redundant page_encryption=1 page_encryption_key=4; |
|||
|
|||
show create table innodb_compact; |
|||
show create table innodb_compressed; |
|||
show create table innodb_dynamic; |
|||
show create table innodb_redundant; |
|||
|
|||
delimiter //; |
|||
create procedure innodb_insert_proc (repeat_count int) |
|||
begin |
|||
declare current_num int; |
|||
set current_num = 0; |
|||
while current_num < repeat_count do |
|||
insert into innodb_normal values(current_num, substring(MD5(RAND()), -64)); |
|||
set current_num = current_num + 1; |
|||
end while; |
|||
end// |
|||
delimiter ;// |
|||
commit; |
|||
|
|||
set autocommit=0; |
|||
call innodb_insert_proc(2000); |
|||
commit; |
|||
set autocommit=1; |
|||
|
|||
insert into innodb_compact select * from innodb_normal; |
|||
insert into innodb_compressed select * from innodb_normal; |
|||
insert into innodb_dynamic select * from innodb_normal; |
|||
insert into innodb_redundant select * from innodb_normal; |
|||
|
|||
update innodb_normal set c1 = c1 +1; |
|||
update innodb_compact set c1 = c1 + 1; |
|||
update innodb_compressed set c1 = c1 + 1; |
|||
update innodb_dynamic set c1 = c1 + 1; |
|||
update innodb_redundant set c1 = c1 + 1; |
|||
select count(*) from innodb_compact where c1 < 1500000; |
|||
select count(*) from innodb_compressed where c1 < 1500000; |
|||
select count(*) from innodb_dynamic where c1 < 1500000; |
|||
select count(*) from innodb_redundant where c1 < 1500000; |
|||
select count(*) from innodb_compact t1, innodb_normal t2 where |
|||
t1.c1 = t2.c1 and t1.b = t2.b; |
|||
select count(*) from innodb_dynamic t1, innodb_normal t2 where |
|||
t1.c1 = t2.c1 and t1.b = t2.b; |
|||
select count(*) from innodb_compressed t1, innodb_normal t2 where |
|||
t1.c1 = t2.c1 and t1.b = t2.b; |
|||
select count(*) from innodb_redundant t1, innodb_normal t2 where |
|||
t1.c1 = t2.c1 and t1.b = t2.b; |
|||
|
|||
# Note there that these variables are updated only when real I/O is done, thus they are not reliable |
|||
SELECT variable_value >= 0 FROM information_schema.global_status WHERE LOWER(variable_name) = 'innodb_num_pages_page_encrypted'; |
|||
SELECT variable_value >= 0 FROM information_schema.global_status WHERE LOWER(variable_name) = 'innodb_num_pages_page_decrypted'; |
|||
SELECT variable_value = 0 FROM information_schema.global_status WHERE LOWER(variable_name) = 'innodb_num_pages_page_encryption_error'; |
|||
|
|||
--source include/restart_mysqld.inc |
|||
|
|||
SET GLOBAL innodb_file_format = `Barracuda`; |
|||
SET GLOBAL innodb_file_per_table = ON; |
|||
|
|||
update innodb_normal set c1 = c1 +1; |
|||
update innodb_compact set c1 = c1 + 1; |
|||
update innodb_compressed set c1 = c1 + 1; |
|||
update innodb_dynamic set c1 = c1 + 1; |
|||
update innodb_redundant set c1 = c1 + 1; |
|||
select count(*) from innodb_compact where c1 < 1500000; |
|||
select count(*) from innodb_compressed where c1 < 1500000; |
|||
select count(*) from innodb_dynamic where c1 < 1500000; |
|||
select count(*) from innodb_redundant where c1 < 1500000; |
|||
select count(*) from innodb_compact t1, innodb_normal t2 where |
|||
t1.c1 = t2.c1 and t1.b = t2.b; |
|||
select count(*) from innodb_dynamic t1, innodb_normal t2 where |
|||
t1.c1 = t2.c1 and t1.b = t2.b; |
|||
select count(*) from innodb_compressed t1, innodb_normal t2 where |
|||
t1.c1 = t2.c1 and t1.b = t2.b; |
|||
select count(*) from innodb_redundant t1, innodb_normal t2 where |
|||
t1.c1 = t2.c1 and t1.b = t2.b; |
|||
|
|||
SELECT variable_value >= 0 FROM information_schema.global_status WHERE LOWER(variable_name) = 'innodb_num_pages_page_encrypted'; |
|||
SELECT variable_value >= 0 FROM information_schema.global_status WHERE LOWER(variable_name) = 'innodb_num_pages_page_decrypted'; |
|||
SELECT variable_value = 0 FROM information_schema.global_status WHERE LOWER(variable_name) = 'innodb_num_pages_page_encryption_error'; |
|||
|
|||
alter table innodb_compact engine=innodb page_encryption=DEFAULT page_encryption_key=DEFAULT; |
|||
show create table innodb_compact; |
|||
alter table innodb_compressed engine=innodb page_encryption=DEFAULT page_encryption_key=DEFAULT; |
|||
show create table innodb_compressed; |
|||
alter table innodb_dynamic engine=innodb page_encryption=DEFAULT page_encryption_key=DEFAULT; |
|||
show create table innodb_dynamic; |
|||
alter table innodb_redundant engine=innodb page_encryption=DEFAULT page_encryption_key=DEFAULT; |
|||
show create table innodb_redundant; |
|||
|
|||
--source include/restart_mysqld.inc |
|||
|
|||
SET GLOBAL innodb_file_format = `Barracuda`; |
|||
SET GLOBAL innodb_file_per_table = ON; |
|||
|
|||
show create table innodb_compact; |
|||
show create table innodb_compressed; |
|||
show create table innodb_dynamic; |
|||
show create table innodb_redundant; |
|||
|
|||
update innodb_normal set c1 = c1 +1; |
|||
update innodb_compact set c1 = c1 + 1; |
|||
update innodb_compressed set c1 = c1 + 1; |
|||
update innodb_dynamic set c1 = c1 + 1; |
|||
update innodb_redundant set c1 = c1 + 1; |
|||
select count(*) from innodb_compact where c1 < 1500000; |
|||
select count(*) from innodb_compressed where c1 < 1500000; |
|||
select count(*) from innodb_dynamic where c1 < 1500000; |
|||
select count(*) from innodb_redundant where c1 < 1500000; |
|||
select count(*) from innodb_compact t1, innodb_normal t2 where |
|||
t1.c1 = t2.c1 and t1.b = t2.b; |
|||
select count(*) from innodb_dynamic t1, innodb_normal t2 where |
|||
t1.c1 = t2.c1 and t1.b = t2.b; |
|||
select count(*) from innodb_compressed t1, innodb_normal t2 where |
|||
t1.c1 = t2.c1 and t1.b = t2.b; |
|||
select count(*) from innodb_redundant t1, innodb_normal t2 where |
|||
t1.c1 = t2.c1 and t1.b = t2.b; |
|||
|
|||
# After alter+restart these should be 0 |
|||
SELECT variable_value = 0 FROM information_schema.global_status WHERE LOWER(variable_name) = 'innodb_num_pages_page_encrypted'; |
|||
SELECT variable_value = 0 FROM information_schema.global_status WHERE LOWER(variable_name) = 'innodb_num_pages_page_decrypted'; |
|||
SELECT variable_value = 0 FROM information_schema.global_status WHERE LOWER(variable_name) = 'innodb_num_pages_page_encryption_error'; |
|||
|
|||
drop procedure innodb_insert_proc; |
|||
drop table innodb_normal; |
|||
drop table innodb_compact; |
|||
drop table innodb_compressed; |
|||
drop table innodb_dynamic; |
|||
drop table innodb_redundant; |
|||
|
|||
# reset system |
|||
--disable_query_log |
|||
EVAL SET GLOBAL innodb_file_per_table = $innodb_file_per_table_orig; |
|||
EVAL SET GLOBAL innodb_file_format = $innodb_file_format_orig; |
|||
--enable_query_log |
|||
Write
Preview
Loading…
Cancel
Save
Reference in new issue