mirror of
https://github.com/MariaDB/server.git
synced 2025-08-08 11:22:35 +03:00
MDEV-8832: Encryption meta data should not be stored when ENCRYPTED=DEFAULT and innodb-encrypt-tables=OFF
This commit is contained in:
@@ -0,0 +1,66 @@
|
|||||||
|
SET GLOBAL innodb_file_format = `Barracuda`;
|
||||||
|
SET GLOBAL innodb_file_per_table = ON;
|
||||||
|
SET GLOBAL innodb_encrypt_tables = OFF;
|
||||||
|
SET GLOBAL innodb_encryption_threads = 4;
|
||||||
|
CREATE TABLE t1 (pk INT PRIMARY KEY AUTO_INCREMENT, c VARCHAR(256)) ENGINE=INNODB;
|
||||||
|
SHOW CREATE TABLE t1;
|
||||||
|
Table Create Table
|
||||||
|
t1 CREATE TABLE `t1` (
|
||||||
|
`pk` int(11) NOT NULL AUTO_INCREMENT,
|
||||||
|
`c` varchar(256) DEFAULT NULL,
|
||||||
|
PRIMARY KEY (`pk`)
|
||||||
|
) ENGINE=InnoDB DEFAULT CHARSET=latin1
|
||||||
|
CREATE TABLE t2 (pk INT PRIMARY KEY AUTO_INCREMENT, c VARCHAR(256)) ENGINE=INNODB ENCRYPTED=YES;
|
||||||
|
CREATE TABLE t3 (pk INT PRIMARY KEY AUTO_INCREMENT, c VARCHAR(256)) ENGINE=INNODB ENCRYPTED=NO;
|
||||||
|
CREATE TABLE t4 (pk INT PRIMARY KEY AUTO_INCREMENT, c VARCHAR(256)) ENGINE=INNODB ENCRYPTED=YES ENCRYPTION_KEY_ID=4;
|
||||||
|
INSERT INTO t2 select * from t1;
|
||||||
|
INSERT INTO t3 select * from t1;
|
||||||
|
INSERT INTO t4 select * from t1;
|
||||||
|
SET GLOBAL innodb_encrypt_tables = on;
|
||||||
|
# Wait max 10 min for key encryption threads to encrypt required all spaces
|
||||||
|
# Success!
|
||||||
|
SELECT COUNT(1) FROM t1;
|
||||||
|
COUNT(1)
|
||||||
|
400
|
||||||
|
SELECT COUNT(1) FROM t2;
|
||||||
|
COUNT(1)
|
||||||
|
400
|
||||||
|
SELECT COUNT(1) FROM t3;
|
||||||
|
COUNT(1)
|
||||||
|
400
|
||||||
|
SELECT COUNT(1) FROM t4;
|
||||||
|
COUNT(1)
|
||||||
|
400
|
||||||
|
SET GLOBAL innodb_encrypt_tables = off;
|
||||||
|
# Wait max 10 min for key encryption threads to decrypt all required spaces
|
||||||
|
# Success!
|
||||||
|
SET GLOBAL innodb_encrypt_tables = ON;
|
||||||
|
set GLOBAL innodb_default_encryption_key_id=4;
|
||||||
|
CREATE TABLE t5 (pk INT PRIMARY KEY AUTO_INCREMENT, c VARCHAR(256)) ENGINE=INNODB;
|
||||||
|
SHOW CREATE TABLE t5;
|
||||||
|
Table Create Table
|
||||||
|
t5 CREATE TABLE `t5` (
|
||||||
|
`pk` int(11) NOT NULL AUTO_INCREMENT,
|
||||||
|
`c` varchar(256) DEFAULT NULL,
|
||||||
|
PRIMARY KEY (`pk`)
|
||||||
|
) ENGINE=InnoDB DEFAULT CHARSET=latin1
|
||||||
|
INSERT INTO t5 select * from t1;
|
||||||
|
# Wait max 10 min for key encryption threads to encrypt required all spaces
|
||||||
|
# Success!
|
||||||
|
SELECT COUNT(1) FROM t1;
|
||||||
|
COUNT(1)
|
||||||
|
400
|
||||||
|
SELECT COUNT(1) FROM t2;
|
||||||
|
COUNT(1)
|
||||||
|
400
|
||||||
|
SELECT COUNT(1) FROM t3;
|
||||||
|
COUNT(1)
|
||||||
|
400
|
||||||
|
SELECT COUNT(1) FROM t4;
|
||||||
|
COUNT(1)
|
||||||
|
400
|
||||||
|
SELECT COUNT(1) FROM t5;
|
||||||
|
COUNT(1)
|
||||||
|
400
|
||||||
|
drop table t1,t2,t3,t4, t5;
|
||||||
|
set GLOBAL innodb_default_encryption_key_id=1;
|
@@ -0,0 +1 @@
|
|||||||
|
--innodb-tablespaces-encryption
|
141
mysql-test/suite/encryption/t/innodb_encryption_filekeys.test
Normal file
141
mysql-test/suite/encryption/t/innodb_encryption_filekeys.test
Normal file
@@ -0,0 +1,141 @@
|
|||||||
|
-- source include/have_innodb.inc
|
||||||
|
-- source include/have_file_key_management_plugin.inc
|
||||||
|
# embedded does not support restart
|
||||||
|
-- source include/not_embedded.inc
|
||||||
|
|
||||||
|
--disable_query_log
|
||||||
|
let $innodb_file_format_orig = `SELECT @@innodb_file_format`;
|
||||||
|
let $innodb_file_per_table_orig = `SELECT @@innodb_file_per_table`;
|
||||||
|
let $encrypt_tables = `SELECT @@innodb_encrypt_tables`;
|
||||||
|
let $threads = `SELECT @@innodb_encryption_threads`;
|
||||||
|
--enable_query_log
|
||||||
|
|
||||||
|
SET GLOBAL innodb_file_format = `Barracuda`;
|
||||||
|
SET GLOBAL innodb_file_per_table = ON;
|
||||||
|
SET GLOBAL innodb_encrypt_tables = OFF;
|
||||||
|
SET GLOBAL innodb_encryption_threads = 4;
|
||||||
|
|
||||||
|
CREATE TABLE t1 (pk INT PRIMARY KEY AUTO_INCREMENT, c VARCHAR(256)) ENGINE=INNODB;
|
||||||
|
SHOW CREATE TABLE t1;
|
||||||
|
CREATE TABLE t2 (pk INT PRIMARY KEY AUTO_INCREMENT, c VARCHAR(256)) ENGINE=INNODB ENCRYPTED=YES;
|
||||||
|
CREATE TABLE t3 (pk INT PRIMARY KEY AUTO_INCREMENT, c VARCHAR(256)) ENGINE=INNODB ENCRYPTED=NO;
|
||||||
|
CREATE TABLE t4 (pk INT PRIMARY KEY AUTO_INCREMENT, c VARCHAR(256)) ENGINE=INNODB ENCRYPTED=YES ENCRYPTION_KEY_ID=4;
|
||||||
|
|
||||||
|
--disable_warnings
|
||||||
|
--disable_query_log
|
||||||
|
set autocommit=0;
|
||||||
|
let $i = 400;
|
||||||
|
while ($i)
|
||||||
|
{
|
||||||
|
INSERT INTO t1 values(NULL, substring(MD5(RAND()), -128));
|
||||||
|
dec $i;
|
||||||
|
}
|
||||||
|
commit;
|
||||||
|
set autocommit=1;
|
||||||
|
--enable_warnings
|
||||||
|
--enable_query_log
|
||||||
|
|
||||||
|
INSERT INTO t2 select * from t1;
|
||||||
|
INSERT INTO t3 select * from t1;
|
||||||
|
INSERT INTO t4 select * from t1;
|
||||||
|
|
||||||
|
SET GLOBAL innodb_encrypt_tables = on;
|
||||||
|
|
||||||
|
--echo # Wait max 10 min for key encryption threads to encrypt required all spaces
|
||||||
|
let $cnt=600;
|
||||||
|
while ($cnt)
|
||||||
|
{
|
||||||
|
let $success=`SELECT COUNT(*) = 1 FROM INFORMATION_SCHEMA.INNODB_TABLESPACES_ENCRYPTION WHERE MIN_KEY_VERSION = 0`;
|
||||||
|
if ($success)
|
||||||
|
{
|
||||||
|
let $cnt=0;
|
||||||
|
}
|
||||||
|
if (!$success)
|
||||||
|
{
|
||||||
|
real_sleep 1;
|
||||||
|
dec $cnt;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (!$success)
|
||||||
|
{
|
||||||
|
SELECT * FROM INFORMATION_SCHEMA.INNODB_TABLESPACES_ENCRYPTION;
|
||||||
|
SHOW STATUS LIKE 'innodb_encryption%';
|
||||||
|
-- die Timeout waiting for encryption threads
|
||||||
|
}
|
||||||
|
--echo # Success!
|
||||||
|
|
||||||
|
SELECT COUNT(1) FROM t1;
|
||||||
|
SELECT COUNT(1) FROM t2;
|
||||||
|
SELECT COUNT(1) FROM t3;
|
||||||
|
SELECT COUNT(1) FROM t4;
|
||||||
|
|
||||||
|
SET GLOBAL innodb_encrypt_tables = off;
|
||||||
|
|
||||||
|
--echo # Wait max 10 min for key encryption threads to decrypt all required spaces
|
||||||
|
let $cnt=600;
|
||||||
|
while ($cnt)
|
||||||
|
{
|
||||||
|
let $success=`SELECT COUNT(*) = 2 FROM INFORMATION_SCHEMA.INNODB_TABLESPACES_ENCRYPTION WHERE MIN_KEY_VERSION <> 0`;
|
||||||
|
if ($success)
|
||||||
|
{
|
||||||
|
let $cnt=0;
|
||||||
|
}
|
||||||
|
if (!$success)
|
||||||
|
{
|
||||||
|
real_sleep 1;
|
||||||
|
dec $cnt;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (!$success)
|
||||||
|
{
|
||||||
|
SELECT * FROM INFORMATION_SCHEMA.INNODB_TABLESPACES_ENCRYPTION;
|
||||||
|
SHOW STATUS LIKE 'innodb_encryption%';
|
||||||
|
-- die Timeout waiting for encryption threads
|
||||||
|
}
|
||||||
|
--echo # Success!
|
||||||
|
|
||||||
|
SET GLOBAL innodb_encrypt_tables = ON;
|
||||||
|
set GLOBAL innodb_default_encryption_key_id=4;
|
||||||
|
CREATE TABLE t5 (pk INT PRIMARY KEY AUTO_INCREMENT, c VARCHAR(256)) ENGINE=INNODB;
|
||||||
|
SHOW CREATE TABLE t5;
|
||||||
|
INSERT INTO t5 select * from t1;
|
||||||
|
|
||||||
|
--echo # Wait max 10 min for key encryption threads to encrypt required all spaces
|
||||||
|
let $cnt=600;
|
||||||
|
while ($cnt)
|
||||||
|
{
|
||||||
|
let $success=`SELECT COUNT(*) = 1 FROM INFORMATION_SCHEMA.INNODB_TABLESPACES_ENCRYPTION WHERE MIN_KEY_VERSION = 0`;
|
||||||
|
if ($success)
|
||||||
|
{
|
||||||
|
let $cnt=0;
|
||||||
|
}
|
||||||
|
if (!$success)
|
||||||
|
{
|
||||||
|
real_sleep 1;
|
||||||
|
dec $cnt;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (!$success)
|
||||||
|
{
|
||||||
|
SELECT * FROM INFORMATION_SCHEMA.INNODB_TABLESPACES_ENCRYPTION;
|
||||||
|
SHOW STATUS LIKE 'innodb_encryption%';
|
||||||
|
-- die Timeout waiting for encryption threads
|
||||||
|
}
|
||||||
|
--echo # Success!
|
||||||
|
|
||||||
|
SELECT COUNT(1) FROM t1;
|
||||||
|
SELECT COUNT(1) FROM t2;
|
||||||
|
SELECT COUNT(1) FROM t3;
|
||||||
|
SELECT COUNT(1) FROM t4;
|
||||||
|
SELECT COUNT(1) FROM t5;
|
||||||
|
|
||||||
|
drop table t1,t2,t3,t4, t5;
|
||||||
|
set GLOBAL innodb_default_encryption_key_id=1;
|
||||||
|
|
||||||
|
# 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;
|
||||||
|
EVAL SET GLOBAL innodb_encrypt_tables = $encrypt_tables;
|
||||||
|
EVAL SET GLOBAL innodb_encryption_threads = $threads;
|
||||||
|
--enable_query_log
|
@@ -3353,6 +3353,7 @@ fil_create_new_single_table_tablespace(
|
|||||||
bool is_temp = !!(flags2 & DICT_TF2_TEMPORARY);
|
bool is_temp = !!(flags2 & DICT_TF2_TEMPORARY);
|
||||||
bool has_data_dir = FSP_FLAGS_HAS_DATA_DIR(flags);
|
bool has_data_dir = FSP_FLAGS_HAS_DATA_DIR(flags);
|
||||||
ulint atomic_writes = FSP_FLAGS_GET_ATOMIC_WRITES(flags);
|
ulint atomic_writes = FSP_FLAGS_GET_ATOMIC_WRITES(flags);
|
||||||
|
fil_space_crypt_t *crypt_data = NULL;
|
||||||
|
|
||||||
ut_a(space_id > 0);
|
ut_a(space_id > 0);
|
||||||
ut_ad(!srv_read_only_mode);
|
ut_ad(!srv_read_only_mode);
|
||||||
@@ -3506,8 +3507,15 @@ fil_create_new_single_table_tablespace(
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Create crypt data if the tablespace is either encrypted or user has
|
||||||
|
requested it to remain unencrypted. */
|
||||||
|
if (mode == FIL_SPACE_ENCRYPTION_ON || mode == FIL_SPACE_ENCRYPTION_OFF ||
|
||||||
|
srv_encrypt_tables) {
|
||||||
|
crypt_data = fil_space_create_crypt_data(mode, key_id);
|
||||||
|
}
|
||||||
|
|
||||||
success = fil_space_create(tablename, space_id, flags, FIL_TABLESPACE,
|
success = fil_space_create(tablename, space_id, flags, FIL_TABLESPACE,
|
||||||
fil_space_create_crypt_data(mode, key_id));
|
crypt_data);
|
||||||
|
|
||||||
if (!success || !fil_node_create(path, size, space_id, FALSE)) {
|
if (!success || !fil_node_create(path, size, space_id, FALSE)) {
|
||||||
err = DB_ERROR;
|
err = DB_ERROR;
|
||||||
@@ -6501,7 +6509,7 @@ fil_iterate(
|
|||||||
|
|
||||||
if (page_compressed) {
|
if (page_compressed) {
|
||||||
ulint len = 0;
|
ulint len = 0;
|
||||||
byte* res = fil_compress_page(space_id,
|
fil_compress_page(space_id,
|
||||||
src,
|
src,
|
||||||
NULL,
|
NULL,
|
||||||
size,
|
size,
|
||||||
|
@@ -3387,6 +3387,7 @@ fil_create_new_single_table_tablespace(
|
|||||||
bool is_temp = !!(flags2 & DICT_TF2_TEMPORARY);
|
bool is_temp = !!(flags2 & DICT_TF2_TEMPORARY);
|
||||||
bool has_data_dir = FSP_FLAGS_HAS_DATA_DIR(flags);
|
bool has_data_dir = FSP_FLAGS_HAS_DATA_DIR(flags);
|
||||||
ulint atomic_writes = FSP_FLAGS_GET_ATOMIC_WRITES(flags);
|
ulint atomic_writes = FSP_FLAGS_GET_ATOMIC_WRITES(flags);
|
||||||
|
fil_space_crypt_t *crypt_data = NULL;
|
||||||
|
|
||||||
ut_a(space_id > 0);
|
ut_a(space_id > 0);
|
||||||
ut_ad(!srv_read_only_mode);
|
ut_ad(!srv_read_only_mode);
|
||||||
@@ -3540,8 +3541,15 @@ fil_create_new_single_table_tablespace(
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Create crypt data if the tablespace is either encrypted or user has
|
||||||
|
requested it to remain unencrypted. */
|
||||||
|
if (mode == FIL_SPACE_ENCRYPTION_ON || mode == FIL_SPACE_ENCRYPTION_OFF ||
|
||||||
|
srv_encrypt_tables) {
|
||||||
|
crypt_data = fil_space_create_crypt_data(mode, key_id);
|
||||||
|
}
|
||||||
|
|
||||||
success = fil_space_create(tablename, space_id, flags, FIL_TABLESPACE,
|
success = fil_space_create(tablename, space_id, flags, FIL_TABLESPACE,
|
||||||
fil_space_create_crypt_data(mode, key_id));
|
crypt_data);
|
||||||
|
|
||||||
if (!success || !fil_node_create(path, size, space_id, FALSE)) {
|
if (!success || !fil_node_create(path, size, space_id, FALSE)) {
|
||||||
err = DB_ERROR;
|
err = DB_ERROR;
|
||||||
@@ -6558,7 +6566,7 @@ fil_iterate(
|
|||||||
|
|
||||||
if (page_compressed) {
|
if (page_compressed) {
|
||||||
ulint len = 0;
|
ulint len = 0;
|
||||||
byte* res = fil_compress_page(space_id,
|
fil_compress_page(space_id,
|
||||||
src,
|
src,
|
||||||
NULL,
|
NULL,
|
||||||
size,
|
size,
|
||||||
|
Reference in New Issue
Block a user