mirror of
https://github.com/MariaDB/server.git
synced 2025-08-08 11:22:35 +03:00
MDEV-21921 Make transaction_isolation and transaction_read_only into system variables
In MariaDB, we have a confusing problem where: * The transaction_isolation option can be set in a configuration file, but it cannot be set dynamically. * The tx_isolation system variable can be set dynamically, but it cannot be set in a configuration file. Therefore, we have two different names for the same thing in different contexts. This is needlessly confusing, and it complicates the documentation. The same thing applys for transaction_read_only. MySQL 5.7 solved this problem by making them into system variables. https://dev.mysql.com/doc/relnotes/mysql/5.7/en/news-5-7-20.html This commit takes a similar approach by adding new system variables and marking the original ones as deprecated. This commit also resolves some legacy problems related to SET STATEMENT and transaction_isolation.
This commit is contained in:
@@ -270,7 +270,7 @@ connection server_2;
|
||||
include/stop_slave.inc
|
||||
SET @old_format= @@GLOBAL.binlog_format;
|
||||
SET GLOBAL binlog_format= MIXED;
|
||||
SET @old_isolation= @@GLOBAL.tx_isolation;
|
||||
SET @old_isolation= @@GLOBAL.transaction_isolation;
|
||||
SET GLOBAL TRANSACTION ISOLATION LEVEL READ COMMITTED;
|
||||
SET GLOBAL slave_parallel_threads=0;
|
||||
SET GLOBAL slave_parallel_threads=10;
|
||||
@@ -346,7 +346,7 @@ a b
|
||||
10 10
|
||||
include/stop_slave.inc
|
||||
SET GLOBAL binlog_format= @old_format;
|
||||
SET GLOBAL tx_isolation= @old_isolation;
|
||||
SET GLOBAL transaction_isolation= @old_isolation;
|
||||
include/start_slave.inc
|
||||
*** MDEV-7888: ANALYZE TABLE does wakeup_subsequent_commits(), causing wrong binlog order and parallel replication hang ***
|
||||
connection server_1;
|
||||
|
@@ -6,7 +6,7 @@ CREATE TABLE t2 (a int PRIMARY KEY, b INT) ENGINE=InnoDB;
|
||||
INSERT INTO t1 VALUES (1,0), (2,0), (3,0);
|
||||
INSERT INTO t2 VALUES (1,0), (2,0);
|
||||
connection server_2;
|
||||
SET @old_isolation= @@GLOBAL.tx_isolation;
|
||||
SET @old_isolation= @@GLOBAL.transaction_isolation;
|
||||
SET @old_parallel_threads=@@GLOBAL.slave_parallel_threads;
|
||||
include/stop_slave.inc
|
||||
SET GLOBAL TRANSACTION ISOLATION LEVEL READ COMMITTED;
|
||||
@@ -82,7 +82,7 @@ a b
|
||||
10 10
|
||||
connection server_2;
|
||||
include/stop_slave.inc
|
||||
SET GLOBAL tx_isolation= @old_isolation;
|
||||
SET GLOBAL transaction_isolation= @old_isolation;
|
||||
SET GLOBAL slave_parallel_mode=@old_parallel_mode;
|
||||
SET GLOBAL slave_parallel_threads=@old_parallel_threads;
|
||||
include/start_slave.inc
|
||||
|
@@ -225,7 +225,7 @@ drop table t1, t2, t3, tm;
|
||||
create table t1 (a int primary key, b int unique) engine=innodb;
|
||||
insert t1 values (1,1),(3,3),(5,5);
|
||||
connection slave;
|
||||
set session tx_isolation='repeatable-read';
|
||||
set session transaction_isolation='repeatable-read';
|
||||
start transaction;
|
||||
select * from t1;
|
||||
a b
|
||||
|
@@ -234,7 +234,7 @@ drop table t1, t2, t3, tm;
|
||||
create table t1 (a int primary key, b int unique) engine=innodb;
|
||||
insert t1 values (1,1),(3,3),(5,5);
|
||||
connection slave;
|
||||
set session tx_isolation='repeatable-read';
|
||||
set session transaction_isolation='repeatable-read';
|
||||
start transaction;
|
||||
select * from t1;
|
||||
a b
|
||||
|
@@ -272,7 +272,7 @@ eval SELECT IF($retry1=$retry2, "Ok, no retry",
|
||||
SET @old_format= @@GLOBAL.binlog_format;
|
||||
# Use MIXED format; we cannot binlog ROW events on slave in STATEMENT format.
|
||||
SET GLOBAL binlog_format= MIXED;
|
||||
SET @old_isolation= @@GLOBAL.tx_isolation;
|
||||
SET @old_isolation= @@GLOBAL.transaction_isolation;
|
||||
SET GLOBAL TRANSACTION ISOLATION LEVEL READ COMMITTED;
|
||||
# Reset the worker threads to make the new settings take effect.
|
||||
SET GLOBAL slave_parallel_threads=0;
|
||||
@@ -317,7 +317,7 @@ SELECT * FROM t2 ORDER BY a;
|
||||
|
||||
--source include/stop_slave.inc
|
||||
SET GLOBAL binlog_format= @old_format;
|
||||
SET GLOBAL tx_isolation= @old_isolation;
|
||||
SET GLOBAL transaction_isolation= @old_isolation;
|
||||
--source include/start_slave.inc
|
||||
|
||||
|
||||
|
@@ -14,7 +14,7 @@ INSERT INTO t2 VALUES (1,0), (2,0);
|
||||
|
||||
--connection server_2
|
||||
--sync_with_master
|
||||
SET @old_isolation= @@GLOBAL.tx_isolation;
|
||||
SET @old_isolation= @@GLOBAL.transaction_isolation;
|
||||
SET @old_parallel_threads=@@GLOBAL.slave_parallel_threads;
|
||||
--source include/stop_slave.inc
|
||||
SET GLOBAL TRANSACTION ISOLATION LEVEL READ COMMITTED;
|
||||
@@ -62,7 +62,7 @@ SELECT * FROM t2 ORDER BY a;
|
||||
|
||||
--connection server_2
|
||||
--source include/stop_slave.inc
|
||||
SET GLOBAL tx_isolation= @old_isolation;
|
||||
SET GLOBAL transaction_isolation= @old_isolation;
|
||||
SET GLOBAL slave_parallel_mode=@old_parallel_mode;
|
||||
SET GLOBAL slave_parallel_threads=@old_parallel_threads;
|
||||
--source include/start_slave.inc
|
||||
|
@@ -363,7 +363,7 @@ sync_slave_with_master;
|
||||
|
||||
# set a strong isolation level to keep the read view below.
|
||||
# alternatively a long-running select can do that too even in read-committed
|
||||
set session tx_isolation='repeatable-read';
|
||||
set session transaction_isolation='repeatable-read';
|
||||
start transaction;
|
||||
# opens a read view to disable purge on the slave
|
||||
select * from t1;
|
||||
|
Reference in New Issue
Block a user