Server IP : 104.21.38.3 / Your IP : 104.23.175.183 Web Server : Apache System : Linux krdc-ubuntu-s-2vcpu-4gb-amd-blr1-01.localdomain 5.15.0-142-generic #152-Ubuntu SMP Mon May 19 10:54:31 UTC 2025 x86_64 User : www ( 1000) PHP Version : 7.4.33 Disable Function : passthru,exec,system,putenv,chroot,chgrp,chown,shell_exec,popen,proc_open,pcntl_exec,ini_alter,ini_restore,dl,openlog,syslog,readlink,symlink,popepassthru,pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,imap_open,apache_setenv MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : OFF | Sudo : ON | Pkexec : ON Directory : /www/server/mysql/src/mysql-test/suite/rpl/t/ |
Upload File : |
# WL#8821 # Testing ALTER INSTANCE ROTATE INNODB MASTER KEY with replication # and keyring installing/uninstalling scenarios on master/slave. --source include/not_embedded.inc --source include/master-slave.inc call mtr.add_suppression("\\[Error\\] Function 'keyring_file' already exists"); call mtr.add_suppression("\\[Error\\] Couldn't load plugin named 'keyring_file' with soname 'keyring_file.so'."); call mtr.add_suppression("\\[Error\\] InnoDB: Can't generate new master key, please check the keyring plugin is loaded."); call mtr.add_suppression("\\[Error\\] InnoDB: Encryption can't find master key, please check the keyring plugin is loaded."); call mtr.add_suppression("Error 'Can't find master key from keyring, please check in the server log if a keyring plugin is loaded and initialized successfully."); call mtr.add_suppression("\\[Warning\\] Slave: Can't find master key from keyring, please check in the server log if a keyring plugin is loaded and initialized successfully."); call mtr.add_suppression("\\[Error\\] InnoDB: Can't generate new master key for tablespace encryption, please check the keyring plugin is loaded."); call mtr.add_suppression("The slave coordinator and worker threads are stopped"); --connection master --echo [On Master] --echo # Roating master key when keyring file is empty. # It should genereate new master key. ALTER INSTANCE ROTATE INNODB MASTER KEY; # Creating table with encryption. CREATE TABLE t1(c1 INT PRIMARY KEY, c2 char(20)) ENCRYPTION="Y" ENGINE = InnoDB; INSERT INTO t1 VALUES(0, "aaaaa"); INSERT INTO t1 VALUES(1, "bbbbb"); INSERT INTO t1 VALUES(2, "ccccc"); SELECT * FROM t1; ALTER INSTANCE ROTATE INNODB MASTER KEY; CREATE TABLE t2(c1 INT PRIMARY KEY, c2 char(20)) ENCRYPTION="Y" ENGINE = InnoDB; INSERT INTO t2 SELECT * FROM t1; SELECT COUNT(*) FROM t2; --echo --echo # Check for keyring file on master. --list_files $MYSQL_TMP_DIR/keyring_master/ --echo # ALTER INSTANCE ROTATE cmd will create keyring file # if it is not exists and new master key in it. ALTER INSTANCE ROTATE INNODB MASTER KEY; --echo # Check for keyring file on master. --list_files $MYSQL_TMP_DIR/keyring_master/ --file_exists $MYSQL_TMP_DIR/keyring_master/keyring_master --echo SELECT * FROM t1; --source include/sync_slave_sql_with_master.inc --echo [On Slave] --echo # Check for keyring file on slave. --list_files $MYSQL_TMP_DIR/keyring_slave/ --file_exists $MYSQL_TMP_DIR/keyring_slave/keyring_slave SELECT COUNT(*) FROM t2; SELECT * FROM t1; --echo # Check for keyring file on slave. --list_files $MYSQL_TMP_DIR/keyring_slave/ --connection master --echo [On Master] --echo # CREATE TABLE t3(c1 INT PRIMARY KEY, c2 char(20)) ENCRYPTION="Y" ENGINE = InnoDB; INSERT INTO t3 VALUES(0, "aaaaa"); --echo --source include/sync_slave_sql_with_master.inc --echo [On Slave] SELECT * FROM t3; SELECT COUNT(*) FROM t2; SELECT * FROM t1; --echo # Check for keyring file on slave. --list_files $MYSQL_TMP_DIR/keyring_slave/ ALTER INSTANCE ROTATE INNODB MASTER KEY; --echo # Check for keyring file on slave. --list_files $MYSQL_TMP_DIR/keyring_slave/ --file_exists $MYSQL_TMP_DIR/keyring_slave/keyring_slave # Uninstalling keyring_file plugin on slave. UNINSTALL PLUGIN keyring_file; --echo # Checking keyring plugin after uninstall. query_vertical SELECT PLUGIN_NAME,PLUGIN_VERSION,PLUGIN_STATUS FROM INFORMATION_SCHEMA.PLUGINS WHERE plugin_name='keyring_file'; --source include/stop_slave_sql.inc --connection master --echo [On Master] CREATE TABLE t4(c1 INT PRIMARY KEY, c2 char(20)) ENCRYPTION="Y" ENGINE = InnoDB; INSERT INTO t4 VALUES(1, "rpltest"); --connection slave --echo [On Slave] START SLAVE SQL_THREAD; --let $slave_sql_errno= convert_error(ER_CANNOT_FIND_KEY_IN_KEYRING) --source include/wait_for_slave_sql_error.inc --replace_regex /\.dll/.so/ eval INSTALL PLUGIN keyring_file SONAME '$KEYRING_PLUGIN'; --replace_result $MYSQL_TMP_DIR MYSQL_TMP_DIR eval SET @@global.keyring_file_data='$MYSQL_TMP_DIR/keyring_slave/keyring_slave'; query_vertical SELECT PLUGIN_NAME,PLUGIN_VERSION,PLUGIN_STATUS FROM INFORMATION_SCHEMA.PLUGINS WHERE plugin_name='keyring_file'; --source include/start_slave_sql.inc --connection master --source include/sync_slave_sql_with_master.inc SELECT * FROM t4; --connection master --echo [On Master] --echo # Uninstalling keyring_file plugin on master. UNINSTALL PLUGIN keyring_file; --echo # Checking keyring plugin after uninstall. query_vertical SELECT PLUGIN_NAME,PLUGIN_VERSION,PLUGIN_STATUS FROM INFORMATION_SCHEMA.PLUGINS WHERE plugin_name='keyring_file'; SELECT * FROM t1; --echo # Try to rotate master key when keyring_file plugin uninstalled. --error ER_CANNOT_FIND_KEY_IN_KEYRING ALTER INSTANCE ROTATE INNODB MASTER KEY; --echo # Installing keyring_file plugin on master. --replace_regex /\.dll/.so/ eval INSTALL PLUGIN keyring_file SONAME '$KEYRING_PLUGIN'; --echo # Cleanup DROP TABLE t1,t2,t3,t4; --source include/sync_slave_sql_with_master.inc --source include/rpl_end.inc # End: