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
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
mariadb
Commits
16ead297
Commit
16ead297
authored
Jun 18, 2009
by
Alfranio Correia
Browse files
Options
Browse Files
Download
Plain Diff
auto-merge mysql-5.1-bugteam (local) --> mysql-5.1-bugteam
parents
0a214a42
ac1b464a
Changes
10
Hide whitespace changes
Inline
Side-by-side
Showing
10 changed files
with
661 additions
and
43 deletions
+661
-43
mysql-test/include/commit.inc
mysql-test/include/commit.inc
+2
-6
mysql-test/r/commit_1innodb.result
mysql-test/r/commit_1innodb.result
+2
-6
mysql-test/suite/rpl/r/rpl_binlog_max_cache_size.result
mysql-test/suite/rpl/r/rpl_binlog_max_cache_size.result
+135
-0
mysql-test/suite/rpl/t/rpl_binlog_max_cache_size-master.opt
mysql-test/suite/rpl/t/rpl_binlog_max_cache_size-master.opt
+1
-0
mysql-test/suite/rpl/t/rpl_binlog_max_cache_size.test
mysql-test/suite/rpl/t/rpl_binlog_max_cache_size.test
+395
-0
sql/log.cc
sql/log.cc
+118
-23
sql/log.h
sql/log.h
+4
-1
sql/sql_delete.cc
sql/sql_delete.cc
+1
-1
sql/sql_insert.cc
sql/sql_insert.cc
+1
-2
sql/sql_update.cc
sql/sql_update.cc
+2
-4
No files found.
mysql-test/include/commit.inc
View file @
16ead297
...
...
@@ -669,13 +669,9 @@ call p_verify_status_increment(1, 0, 1, 0);
insert
t1
set
a
=
3
;
call
p_verify_status_increment
(
2
,
2
,
2
,
2
);
savepoint
a
;
call
p_verify_status_increment
(
0
,
0
,
0
,
0
);
call
p_verify_status_increment
(
1
,
0
,
0
,
0
);
insert
t1
set
a
=
4
;
--
echo
# Binlog does not register itself this time for other than the 1st
--
echo
# statement of the transaction with MIXED/STATEMENT binlog_format.
--
echo
# It needs registering with the ROW format. Therefore 1,0,2,2 are
--
echo
# the correct arguments to this test after bug#40221 fixed.
call
p_verify_status_increment
(
1
,
0
,
2
,
2
);
call
p_verify_status_increment
(
2
,
2
,
2
,
2
);
release
savepoint
a
;
rollback
;
call
p_verify_status_increment
(
0
,
0
,
0
,
0
);
...
...
mysql-test/r/commit_1innodb.result
View file @
16ead297
...
...
@@ -766,15 +766,11 @@ call p_verify_status_increment(2, 2, 2, 2);
SUCCESS
savepoint a;
call p_verify_status_increment(
0
, 0, 0, 0);
call p_verify_status_increment(
1
, 0, 0, 0);
SUCCESS
insert t1 set a=4;
# Binlog does not register itself this time for other than the 1st
# statement of the transaction with MIXED/STATEMENT binlog_format.
# It needs registering with the ROW format. Therefore 1,0,2,2 are
# the correct arguments to this test after bug#40221 fixed.
call p_verify_status_increment(1, 0, 2, 2);
call p_verify_status_increment(2, 2, 2, 2);
SUCCESS
release savepoint a;
...
...
mysql-test/suite/rpl/r/rpl_binlog_max_cache_size.result
0 → 100644
View file @
16ead297
stop slave;
drop table if exists t1,t2,t3,t4,t5,t6,t7,t8,t9;
reset master;
reset slave;
drop table if exists t1,t2,t3,t4,t5,t6,t7,t8,t9;
start slave;
CREATE TABLE t1(a INT PRIMARY KEY, data VARCHAR(30000)) ENGINE=Innodb;
CREATE TABLE t2(a INT PRIMARY KEY, data VARCHAR(30000)) ENGINE=MyIsam;
CREATE TABLE t3(a INT PRIMARY KEY, data VARCHAR(30000)) ENGINE=Innodb;
########################################################################################
# 1 - SINGLE STATEMENT
########################################################################################
*** Single statement on transactional table ***
Got one of the listed errors
*** Single statement on non-transactional table ***
*** After WL#2687 the difference between STATEMENT/MIXED and ROW will not exist. ***
Got one of the listed errors
*** Single statement on both transactional and non-transactional tables. ***
*** After WL#2687 we will be able to change the order of the tables. ***
Got one of the listed errors
SET GLOBAL SQL_SLAVE_SKIP_COUNTER = 1;
START SLAVE SQL_THREAD;
TRUNCATE TABLE t1;
TRUNCATE TABLE t2;
TRUNCATE TABLE t3;
BEGIN;
Got one of the listed errors
Got one of the listed errors
Got one of the listed errors
BEGIN;
Got one of the listed errors
Got one of the listed errors
Got one of the listed errors
BEGIN;
Got one of the listed errors
Got one of the listed errors
source include/diff_master_slave.inc;
########################################################################################
# 3 - BEGIN - COMMIT
########################################################################################
TRUNCATE TABLE t1;
TRUNCATE TABLE t2;
TRUNCATE TABLE t3;
BEGIN;
Got one of the listed errors
Got one of the listed errors
Got one of the listed errors
COMMIT;
source include/diff_master_slave.inc;
########################################################################################
# 4 - BEGIN - ROLLBACK
########################################################################################
TRUNCATE TABLE t1;
TRUNCATE TABLE t2;
TRUNCATE TABLE t3;
BEGIN;
Got one of the listed errors
Got one of the listed errors
Got one of the listed errors
ROLLBACK;
Warnings:
Warning 1196 Some non-transactional changed tables couldn't be rolled back
source include/diff_master_slave.inc;
########################################################################################
# 5 - PROCEDURE
########################################################################################
TRUNCATE TABLE t1;
TRUNCATE TABLE t2;
TRUNCATE TABLE t3;
CREATE PROCEDURE p1(pd VARCHAR(30000))
BEGIN
INSERT INTO t1 (a, data) VALUES (1, pd);
INSERT INTO t1 (a, data) VALUES (2, pd);
INSERT INTO t1 (a, data) VALUES (3, pd);
INSERT INTO t1 (a, data) VALUES (4, pd);
INSERT INTO t1 (a, data) VALUES (5, 's');
END//
TRUNCATE TABLE t1;
TRUNCATE TABLE t1;
BEGIN;
Got one of the listed errors
COMMIT;
TRUNCATE TABLE t1;
BEGIN;
Got one of the listed errors
ROLLBACK;
source include/diff_master_slave.inc;
########################################################################################
# 6 - XID
########################################################################################
TRUNCATE TABLE t1;
TRUNCATE TABLE t2;
TRUNCATE TABLE t3;
BEGIN;
Got one of the listed errors
Got one of the listed errors
Got one of the listed errors
ROLLBACK TO sv;
Warnings:
Warning 1196 Some non-transactional changed tables couldn't be rolled back
COMMIT;
source include/diff_master_slave.inc;
########################################################################################
# 7 - NON-TRANS TABLE
########################################################################################
TRUNCATE TABLE t1;
TRUNCATE TABLE t2;
TRUNCATE TABLE t3;
BEGIN;
Got one of the listed errors
Got one of the listed errors
Got one of the listed errors
Got one of the listed errors
Got one of the listed errors
COMMIT;
BEGIN;
Got one of the listed errors
COMMIT;
########################################################################################
# CLEAN
########################################################################################
DROP TABLE t1;
DROP TABLE t2;
DROP TABLE t3;
DROP TABLE IF EXISTS t4;
DROP TABLE IF EXISTS t5;
DROP TABLE IF EXISTS t6;
DROP PROCEDURE p1;
DROP TABLE t1;
DROP TABLE t2;
DROP TABLE t3;
DROP TABLE IF EXISTS t4;
DROP TABLE IF EXISTS t5;
DROP TABLE IF EXISTS t6;
DROP PROCEDURE p1;
mysql-test/suite/rpl/t/rpl_binlog_max_cache_size-master.opt
0 → 100644
View file @
16ead297
--binlog_cache_size=4096 --max_binlog_cache_size=7680
mysql-test/suite/rpl/t/rpl_binlog_max_cache_size.test
0 → 100644
View file @
16ead297
########################################################################################
# This test verifies if the binlog is not corrupted when the cache buffer is not
# big enough to accommodate the changes and is divided in five steps:
#
# 1 - Single Statements:
# 1.1 - Single statement on transactional table.
# 1.2 - Single statement on non-transactional table.
# 1.3 - Single statement on both transactional and non-transactional tables.
# In both 1.2 and 1.3, an incident event is logged to notify the user that the
# master and slave are diverging.
#
# 2 - Transactions ended by an implicit commit.
#
# 3 - Transactions ended by a COMMIT.
#
# 4 - Transactions ended by a ROLLBACK.
#
# 5 - Transactions with a failing statement that updates a non-transactional
# table. In this case, a failure means that the statement does not get into
# the cache and an incident event is logged to notify the user that the master
# and slave are diverging.
#
########################################################################################
########################################################################################
# Configuring the environment
########################################################################################
--
source
include
/
have_innodb
.
inc
--
source
include
/
master
-
slave
.
inc
--
source
include
/
not_embedded
.
inc
--
source
include
/
not_windows
.
inc
CREATE
TABLE
t1
(
a
INT
PRIMARY
KEY
,
data
VARCHAR
(
30000
))
ENGINE
=
Innodb
;
CREATE
TABLE
t2
(
a
INT
PRIMARY
KEY
,
data
VARCHAR
(
30000
))
ENGINE
=
MyIsam
;
CREATE
TABLE
t3
(
a
INT
PRIMARY
KEY
,
data
VARCHAR
(
30000
))
ENGINE
=
Innodb
;
let
$data
=
`select concat('"', repeat('a',2000), '"')`
;
--
echo
########################################################################################
--
echo
# 1 - SINGLE STATEMENT
--
echo
########################################################################################
connection
master
;
--
echo
***
Single
statement
on
transactional
table
***
--
disable_query_log
--
error
ER_TRANS_CACHE_FULL
,
ER_ERROR_ON_WRITE
eval
INSERT
INTO
t1
(
a
,
data
)
VALUES
(
1
,
CONCAT
(
$data
,
$data
,
$data
,
$data
,
$data
));
--
enable_query_log
--
echo
***
Single
statement
on
non
-
transactional
table
***
--
echo
***
After
WL
#2687 the difference between STATEMENT/MIXED and ROW will not exist. ***
--
disable_query_log
--
disable_warnings
if
(
`SELECT @@binlog_format = 'STATEMENT' || @@binlog_format = 'MIXED'`
)
{
eval
INSERT
INTO
t2
(
a
,
data
)
VALUES
(
2
,
CONCAT
(
$data
,
$data
,
$data
,
$data
,
$data
,
$data
));
--
echo
Got
one
of
the
listed
errors
}
if
(
`SELECT @@binlog_format = 'ROW'`
)
{
--
error
ER_TRANS_CACHE_FULL
,
ER_ERROR_ON_WRITE
eval
INSERT
INTO
t2
(
a
,
data
)
VALUES
(
2
,
CONCAT
(
$data
,
$data
,
$data
,
$data
,
$data
,
$data
));
connection
slave
;
--
source
include
/
wait_for_slave_sql_to_stop
.
inc
SET
GLOBAL
SQL_SLAVE_SKIP_COUNTER
=
1
;
START
SLAVE
SQL_THREAD
;
--
source
include
/
wait_for_slave_sql_to_start
.
inc
}
--
enable_warnings
--
enable_query_log
connection
master
;
--
disable_query_log
eval
INSERT
INTO
t1
(
a
,
data
)
VALUES
(
3
,
$data
);
eval
INSERT
INTO
t1
(
a
,
data
)
VALUES
(
4
,
$data
);
eval
INSERT
INTO
t1
(
a
,
data
)
VALUES
(
5
,
$data
);
eval
INSERT
INTO
t2
(
a
,
data
)
VALUES
(
3
,
$data
);
eval
INSERT
INTO
t2
(
a
,
data
)
VALUES
(
4
,
$data
);
eval
INSERT
INTO
t2
(
a
,
data
)
VALUES
(
5
,
$data
);
--
enable_query_log
--
echo
***
Single
statement
on
both
transactional
and
non
-
transactional
tables
.
***
--
echo
***
After
WL
#2687 we will be able to change the order of the tables. ***
--
disable_query_log
--
error
ER_TRANS_CACHE_FULL
,
ER_ERROR_ON_WRITE
eval
UPDATE
t2
,
t1
SET
t2
.
data
=
CONCAT
(
$data
,
$data
,
$data
,
$data
),
t1
.
data
=
CONCAT
(
$data
,
$data
,
$data
,
$data
);
--
enable_query_log
connection
slave
;
--
source
include
/
wait_for_slave_sql_to_stop
.
inc
SET
GLOBAL
SQL_SLAVE_SKIP_COUNTER
=
1
;
START
SLAVE
SQL_THREAD
;
--
source
include
/
wait_for_slave_sql_to_start
.
inc
#--echo ########################################################################################
#--echo # 2 - BEGIN - IMPLICIT COMMIT by DDL
#--echo ########################################################################################
connection
master
;
TRUNCATE
TABLE
t1
;
TRUNCATE
TABLE
t2
;
TRUNCATE
TABLE
t3
;
BEGIN
;
--
disable_query_log
--
eval
INSERT
INTO
t1
(
a
,
data
)
VALUES
(
1
,
$data
);
--
eval
INSERT
INTO
t1
(
a
,
data
)
VALUES
(
2
,
$data
);
--
eval
INSERT
INTO
t1
(
a
,
data
)
VALUES
(
3
,
$data
);
--
error
ER_TRANS_CACHE_FULL
,
ER_ERROR_ON_WRITE
--
eval
INSERT
INTO
t1
(
a
,
data
)
VALUES
(
4
,
$data
);
--
error
ER_TRANS_CACHE_FULL
,
ER_ERROR_ON_WRITE
--
eval
INSERT
INTO
t1
(
a
,
data
)
VALUES
(
5
,
$data
);
--
error
ER_TRANS_CACHE_FULL
,
ER_ERROR_ON_WRITE
--
eval
INSERT
INTO
t1
(
a
,
data
)
VALUES
(
6
,
$data
);
--
eval
INSERT
INTO
t1
(
a
,
data
)
VALUES
(
7
,
's'
);
--
eval
INSERT
INTO
t2
(
a
,
data
)
VALUES
(
8
,
's'
);
--
eval
INSERT
INTO
t1
(
a
,
data
)
VALUES
(
9
,
's'
);
--
enable_query_log
--
disable_query_log
ALTER
TABLE
t3
ADD
COLUMN
d
int
;
--
enable_query_log
--
disable_query_log
--
eval
INSERT
INTO
t2
(
a
,
data
)
VALUES
(
10
,
$data
);
--
eval
INSERT
INTO
t2
(
a
,
data
)
VALUES
(
11
,
$data
);
--
eval
INSERT
INTO
t2
(
a
,
data
)
VALUES
(
12
,
$data
);
--
eval
INSERT
INTO
t2
(
a
,
data
)
VALUES
(
13
,
$data
);
--
enable_query_log
BEGIN
;
--
disable_query_log
--
eval
INSERT
INTO
t1
(
a
,
data
)
VALUES
(
14
,
$data
);
--
eval
INSERT
INTO
t1
(
a
,
data
)
VALUES
(
15
,
$data
);
--
eval
INSERT
INTO
t1
(
a
,
data
)
VALUES
(
16
,
$data
);
--
error
ER_TRANS_CACHE_FULL
,
ER_ERROR_ON_WRITE
--
eval
INSERT
INTO
t1
(
a
,
data
)
VALUES
(
17
,
$data
);
--
error
ER_TRANS_CACHE_FULL
,
ER_ERROR_ON_WRITE
--
eval
INSERT
INTO
t1
(
a
,
data
)
VALUES
(
18
,
$data
);
--
eval
INSERT
INTO
t1
(
a
,
data
)
VALUES
(
19
,
's'
);
--
eval
INSERT
INTO
t2
(
a
,
data
)
VALUES
(
20
,
's'
);
--
eval
INSERT
INTO
t1
(
a
,
data
)
VALUES
(
21
,
's'
);
--
enable_query_log
if
(
`SELECT @@binlog_format = 'STATEMENT' || @@binlog_format = 'MIXED'`
)
{
--
disable_query_log
CREATE
TABLE
t4
SELECT
*
FROM
t1
;
--
enable_query_log
--
echo
Got
one
of
the
listed
errors
}
if
(
`SELECT @@binlog_format = 'ROW'`
)
{
--
disable_query_log
--
error
ER_TRANS_CACHE_FULL
,
ER_ERROR_ON_WRITE
CREATE
TABLE
t4
SELECT
*
FROM
t1
;
--
enable_query_log
}
--
disable_query_log
--
eval
INSERT
INTO
t2
(
a
,
data
)
VALUES
(
15
,
$data
);
--
enable_query_log
BEGIN
;
--
disable_query_log
--
eval
INSERT
INTO
t1
(
a
,
data
)
VALUES
(
22
,
$data
);
--
eval
INSERT
INTO
t1
(
a
,
data
)
VALUES
(
23
,
$data
);
--
eval
INSERT
INTO
t1
(
a
,
data
)
VALUES
(
24
,
$data
);
--
error
ER_TRANS_CACHE_FULL
,
ER_ERROR_ON_WRITE
--
eval
INSERT
INTO
t1
(
a
,
data
)
VALUES
(
25
,
$data
);
--
error
ER_TRANS_CACHE_FULL
,
ER_ERROR_ON_WRITE
--
eval
INSERT
INTO
t1
(
a
,
data
)
VALUES
(
26
,
$data
);
--
eval
INSERT
INTO
t1
(
a
,
data
)
VALUES
(
27
,
's'
);
--
eval
INSERT
INTO
t2
(
a
,
data
)
VALUES
(
28
,
's'
);
--
eval
INSERT
INTO
t1
(
a
,
data
)
VALUES
(
29
,
's'
);
--
enable_query_log
--
disable_query_log
CREATE
TABLE
t5
(
a
int
);
--
enable_query_log
let
$diff_statement
=
SELECT
*
FROM
t1
;
--
source
include
/
diff_master_slave
.
inc
--
echo
########################################################################################
--
echo
# 3 - BEGIN - COMMIT
--
echo
########################################################################################
connection
master
;
TRUNCATE
TABLE
t1
;
TRUNCATE
TABLE
t2
;
TRUNCATE
TABLE
t3
;
BEGIN
;
--
disable_query_log
--
eval
INSERT
INTO
t1
(
a
,
data
)
VALUES
(
1
,
$data
);
--
eval
INSERT
INTO
t1
(
a
,
data
)
VALUES
(
2
,
$data
);
--
eval
INSERT
INTO
t1
(
a
,
data
)
VALUES
(
3
,
$data
);
--
error
ER_TRANS_CACHE_FULL
,
ER_ERROR_ON_WRITE
--
eval
INSERT
INTO
t1
(
a
,
data
)
VALUES
(
4
,
$data
);
--
error
ER_TRANS_CACHE_FULL
,
ER_ERROR_ON_WRITE
--
eval
INSERT
INTO
t1
(
a
,
data
)
VALUES
(
5
,
$data
);
--
error
ER_TRANS_CACHE_FULL
,
ER_ERROR_ON_WRITE
--
eval
INSERT
INTO
t1
(
a
,
data
)
VALUES
(
6
,
$data
);
--
eval
INSERT
INTO
t1
(
a
,
data
)
VALUES
(
7
,
's'
);
--
eval
INSERT
INTO
t2
(
a
,
data
)
VALUES
(
8
,
's'
);
--
eval
INSERT
INTO
t1
(
a
,
data
)
VALUES
(
9
,
's'
);
--
enable_query_log
COMMIT
;
let
$diff_statement
=
SELECT
*
FROM
t1
;
--
source
include
/
diff_master_slave
.
inc
--
echo
########################################################################################
--
echo
# 4 - BEGIN - ROLLBACK
--
echo
########################################################################################
connection
master
;
TRUNCATE
TABLE
t1
;
TRUNCATE
TABLE
t2
;
TRUNCATE
TABLE
t3
;
BEGIN
;
--
disable_query_log
--
eval
INSERT
INTO
t1
(
a
,
data
)
VALUES
(
1
,
$data
);
--
eval
INSERT
INTO
t1
(
a
,
data
)
VALUES
(
2
,
$data
);
--
eval
INSERT
INTO
t1
(
a
,
data
)
VALUES
(
3
,
$data
);
--
error
ER_TRANS_CACHE_FULL
,
ER_ERROR_ON_WRITE
--
eval
INSERT
INTO
t1
(
a
,
data
)
VALUES
(
4
,
$data
);
--
error
ER_TRANS_CACHE_FULL
,
ER_ERROR_ON_WRITE
--
eval
INSERT
INTO
t1
(
a
,
data
)
VALUES
(
5
,
$data
);
--
error
ER_TRANS_CACHE_FULL
,
ER_ERROR_ON_WRITE
--
eval
INSERT
INTO
t1
(
a
,
data
)
VALUES
(
6
,
$data
);
--
eval
INSERT
INTO
t1
(
a
,
data
)
VALUES
(
7
,
's'
);
--
eval
INSERT
INTO
t2
(
a
,
data
)
VALUES
(
8
,
's'
);
--
eval
INSERT
INTO
t1
(
a
,
data
)
VALUES
(
9
,
's'
);
--
enable_query_log
ROLLBACK
;
let
$diff_statement
=
SELECT
*
FROM
t1
;
--
source
include
/
diff_master_slave
.
inc
--
echo
########################################################################################
--
echo
# 5 - PROCEDURE
--
echo
########################################################################################
connection
master
;
TRUNCATE
TABLE
t1
;
TRUNCATE
TABLE
t2
;
TRUNCATE
TABLE
t3
;
DELIMITER
//;
CREATE
PROCEDURE
p1
(
pd
VARCHAR
(
30000
))
BEGIN
INSERT
INTO
t1
(
a
,
data
)
VALUES
(
1
,
pd
);
INSERT
INTO
t1
(
a
,
data
)
VALUES
(
2
,
pd
);
INSERT
INTO
t1
(
a
,
data
)
VALUES
(
3
,
pd
);
INSERT
INTO
t1
(
a
,
data
)
VALUES
(
4
,
pd
);
INSERT
INTO
t1
(
a
,
data
)
VALUES
(
5
,
's'
);
END
//
DELIMITER
;
//
TRUNCATE
TABLE
t1
;
--
disable_query_log
eval
CALL
p1
(
$data
);
--
enable_query_log
TRUNCATE
TABLE
t1
;
BEGIN
;
--
disable_query_log
--
error
ER_TRANS_CACHE_FULL
,
ER_ERROR_ON_WRITE
eval
CALL
p1
(
$data
);
--
enable_query_log
COMMIT
;
TRUNCATE
TABLE
t1
;
BEGIN
;
--
disable_query_log
--
error
ER_TRANS_CACHE_FULL
,
ER_ERROR_ON_WRITE
eval
CALL
p1
(
$data
);
--
enable_query_log
ROLLBACK
;
let
$diff_statement
=
SELECT
*
FROM
t1
;
--
source
include
/
diff_master_slave
.
inc
--
echo
########################################################################################
--
echo
# 6 - XID
--
echo
########################################################################################
connection
master
;
TRUNCATE
TABLE
t1
;
TRUNCATE
TABLE
t2
;
TRUNCATE
TABLE
t3
;
BEGIN
;
--
disable_query_log
--
eval
INSERT
INTO
t1
(
a
,
data
)
VALUES
(
1
,
$data
);
--
eval
INSERT
INTO
t1
(
a
,
data
)
VALUES
(
2
,
$data
);
--
eval
INSERT
INTO
t1
(
a
,
data
)
VALUES
(
3
,
$data
);
--
error
ER_TRANS_CACHE_FULL
,
ER_ERROR_ON_WRITE
--
eval
INSERT
INTO
t1
(
a
,
data
)
VALUES
(
4
,
$data
);
SAVEPOINT
sv
;
--
error
ER_TRANS_CACHE_FULL
,
ER_ERROR_ON_WRITE
--
eval
INSERT
INTO
t1
(
a
,
data
)
VALUES
(
5
,
$data
);
--
error
ER_TRANS_CACHE_FULL
,
ER_ERROR_ON_WRITE
--
eval
INSERT
INTO
t1
(
a
,
data
)
VALUES
(
6
,
$data
);
--
eval
INSERT
INTO
t1
(
a
,
data
)
VALUES
(
7
,
's'
);
--
eval
INSERT
INTO
t2
(
a
,
data
)
VALUES
(
8
,
's'
);
--
eval
INSERT
INTO
t1
(
a
,
data
)
VALUES
(
9
,
's'
);
--
enable_query_log
ROLLBACK
TO
sv
;
COMMIT
;
let
$diff_statement
=
SELECT
*
FROM
t1
;
--
source
include
/
diff_master_slave
.
inc
--
echo
########################################################################################
--
echo
# 7 - NON-TRANS TABLE
--
echo
########################################################################################
connection
master
;
TRUNCATE
TABLE
t1
;
TRUNCATE
TABLE
t2
;
TRUNCATE
TABLE
t3
;
BEGIN
;
--
disable_query_log
--
eval
INSERT
INTO
t1
(
a
,
data
)
VALUES
(
1
,
$data
);
--
eval
INSERT
INTO
t1
(
a
,
data
)
VALUES
(
2
,
$data
);
--
eval
INSERT
INTO
t2
(
a
,
data
)
VALUES
(
3
,
$data
);
--
error
ER_TRANS_CACHE_FULL
,
ER_ERROR_ON_WRITE
--
eval
INSERT
INTO
t1
(
a
,
data
)
VALUES
(
4
,
$data
);
--
error
ER_TRANS_CACHE_FULL
,
ER_ERROR_ON_WRITE
--
eval
INSERT
INTO
t1
(
a
,
data
)
VALUES
(
5
,
$data
);
--
error
ER_TRANS_CACHE_FULL
,
ER_ERROR_ON_WRITE
--
eval
INSERT
INTO
t1
(
a
,
data
)
VALUES
(
6
,
$data
);
--
error
ER_TRANS_CACHE_FULL
,
ER_ERROR_ON_WRITE
--
eval
INSERT
INTO
t1
(
a
,
data
)
VALUES
(
7
,
$data
);
--
error
ER_TRANS_CACHE_FULL
,
ER_ERROR_ON_WRITE
--
eval
UPDATE
t2
SET
data
=
CONCAT
(
$data
,
$data
);
--
eval
INSERT
INTO
t1
(
a
,
data
)
VALUES
(
8
,
's'
);
--
eval
INSERT
INTO
t1
(
a
,
data
)
VALUES
(
9
,
's'
);
--
eval
INSERT
INTO
t2
(
a
,
data
)
VALUES
(
10
,
's'
);
--
eval
INSERT
INTO
t1
(
a
,
data
)
VALUES
(
11
,
's'
);
--
enable_query_log
COMMIT
;
BEGIN
;
--
disable_query_log
--
eval
INSERT
INTO
t1
(
a
,
data
)
VALUES
(
15
,
$data
);
--
eval
INSERT
INTO
t1
(
a
,
data
)
VALUES
(
16
,
$data
);
--
eval
INSERT
INTO
t2
(
a
,
data
)
VALUES
(
17
,
$data
);
--
error
ER_TRANS_CACHE_FULL
,
ER_ERROR_ON_WRITE
--
eval
INSERT
INTO
t1
(
a
,
data
)
VALUES
(
18
,
$data
);
--
enable_query_log
COMMIT
;
connection
slave
;
--
source
include
/
wait_for_slave_sql_to_stop
.
inc
--
echo
########################################################################################
--
echo
# CLEAN
--
echo
########################################################################################
--
disable_warnings
connection
master
;
DROP
TABLE
t1
;
DROP
TABLE
t2
;
DROP
TABLE
t3
;
DROP
TABLE
IF
EXISTS
t4
;
DROP
TABLE
IF
EXISTS
t5
;
DROP
TABLE
IF
EXISTS
t6
;
DROP
PROCEDURE
p1
;
connection
slave
;
DROP
TABLE
t1
;
DROP
TABLE
t2
;
DROP
TABLE
t3
;
DROP
TABLE
IF
EXISTS
t4
;
DROP
TABLE
IF
EXISTS
t5
;
DROP
TABLE
IF
EXISTS
t6
;
DROP
PROCEDURE
p1
;
--
enable_warnings
sql/log.cc
View file @
16ead297
...
...
@@ -153,7 +153,8 @@ private:
class
binlog_trx_data
{
public:
binlog_trx_data
()
:
at_least_one_stmt
(
0
),
m_pending
(
0
),
before_stmt_pos
(
MY_OFF_T_UNDEF
)
:
at_least_one_stmt
(
0
),
incident
(
FALSE
),
m_pending
(
0
),
before_stmt_pos
(
MY_OFF_T_UNDEF
)
{
trans_log
.
end_of_file
=
max_binlog_cache_size
;
}
...
...
@@ -184,6 +185,7 @@ public:
delete
pending
();
set_pending
(
0
);
reinit_io_cache
(
&
trans_log
,
WRITE_CACHE
,
pos
,
0
,
0
);
trans_log
.
end_of_file
=
max_binlog_cache_size
;
if
(
pos
<
before_stmt_pos
)
before_stmt_pos
=
MY_OFF_T_UNDEF
;
...
...
@@ -206,6 +208,7 @@ public:
if
(
!
empty
())
truncate
(
0
);
before_stmt_pos
=
MY_OFF_T_UNDEF
;
incident
=
FALSE
;
trans_log
.
end_of_file
=
max_binlog_cache_size
;
DBUG_ASSERT
(
empty
());
}
...
...
@@ -222,11 +225,22 @@ public:
IO_CACHE
trans_log
;
// The transaction cache
void
set_incident
(
void
)
{
incident
=
TRUE
;
}
bool
has_incident
(
void
)
{
return
(
incident
);
}
/**
Boolean that is true if there is at least one statement in the
transaction cache.
*/
bool
at_least_one_stmt
;
bool
incident
;
private:
/*
...
...
@@ -1391,7 +1405,8 @@ binlog_end_trans(THD *thd, binlog_trx_data *trx_data,
*/
if
(
end_ev
!=
NULL
)
{
thd
->
binlog_flush_pending_rows_event
(
TRUE
);
if
(
thd
->
binlog_flush_pending_rows_event
(
TRUE
))
DBUG_RETURN
(
1
);
/*
Doing a commit or a rollback including non-transactional tables,
i.e., ending a transaction where we might write the transaction
...
...
@@ -1402,7 +1417,8 @@ binlog_end_trans(THD *thd, binlog_trx_data *trx_data,
were, we would have to ensure that we're not ending a statement
inside a stored function.
*/
error
=
mysql_bin_log
.
write
(
thd
,
&
trx_data
->
trans_log
,
end_ev
);
error
=
mysql_bin_log
.
write
(
thd
,
&
trx_data
->
trans_log
,
end_ev
,
trx_data
->
has_incident
());
trx_data
->
reset
();
/*
...
...
@@ -1428,7 +1444,11 @@ binlog_end_trans(THD *thd, binlog_trx_data *trx_data,
*/
thd
->
binlog_remove_pending_rows_event
(
TRUE
);
if
(
all
||
!
(
thd
->
options
&
(
OPTION_BEGIN
|
OPTION_NOT_AUTOCOMMIT
)))
{
if
(
trx_data
->
has_incident
())
mysql_bin_log
.
write_incident
(
thd
,
TRUE
);
trx_data
->
reset
();
}
else
// ...statement
trx_data
->
truncate
(
trx_data
->
before_stmt_pos
);
...
...
@@ -1544,9 +1564,11 @@ static int binlog_rollback(handlerton *hton, THD *thd, bool all)
YESNO
(
all
),
YESNO
(
thd
->
transaction
.
all
.
modified_non_trans_table
),
YESNO
(
thd
->
transaction
.
stmt
.
modified_non_trans_table
)));
if
(
all
&&
thd
->
transaction
.
all
.
modified_non_trans_table
||
!
all
&&
thd
->
transaction
.
stmt
.
modified_non_trans_table
||
(
thd
->
options
&
OPTION_KEEP_LOG
))
if
((
all
&&
thd
->
transaction
.
all
.
modified_non_trans_table
)
||
(
!
all
&&
thd
->
transaction
.
stmt
.
modified_non_trans_table
&&
!
mysql_bin_log
.
check_write_error
(
thd
))
||
((
thd
->
options
&
OPTION_KEEP_LOG
)
&&
!
mysql_bin_log
.
check_write_error
(
thd
)))
{
/*
We write the transaction cache with a rollback last if we have
...
...
@@ -1559,14 +1581,22 @@ static int binlog_rollback(handlerton *hton, THD *thd, bool all)
Query_log_event
qev
(
thd
,
STRING_WITH_LEN
(
"ROLLBACK"
),
TRUE
,
TRUE
,
0
);
error
=
binlog_end_trans
(
thd
,
trx_data
,
&
qev
,
all
);
}
else
if
(
all
&&
!
thd
->
transaction
.
all
.
modified_non_trans_table
||
!
all
&&
!
thd
->
transaction
.
stmt
.
modified_non_trans_table
)
else
{
/*
If we have modified only transactional tables, we can truncate
the transaction cache without writing anything to the binary
log.
We reach this point if either only transactional tables were modified or
the effect of a statement that did not get into the binlog needs to be
rolled back. In the latter case, if a statement changed non-transactional
tables or had the OPTION_KEEP_LOG associated, we write an incident event
to the binlog in order to stop slaves and notify users that some changes
on the master did not get into the binlog and slaves will be inconsistent.
On the other hand, if a statement is transactional, we just safely roll it
back.
*/
if
((
thd
->
transaction
.
stmt
.
modified_non_trans_table
||
(
thd
->
options
&
OPTION_KEEP_LOG
))
&&
mysql_bin_log
.
check_write_error
(
thd
))
trx_data
->
set_incident
();
error
=
binlog_end_trans
(
thd
,
trx_data
,
0
,
all
);
}
if
(
!
all
)
...
...
@@ -1574,6 +1604,44 @@ static int binlog_rollback(handlerton *hton, THD *thd, bool all)
DBUG_RETURN
(
error
);
}
void
MYSQL_BIN_LOG
::
set_write_error
(
THD
*
thd
)
{
DBUG_ENTER
(
"MYSQL_BIN_LOG::set_write_error"
);
write_error
=
1
;
if
(
check_write_error
(
thd
))
DBUG_VOID_RETURN
;
if
(
my_errno
==
EFBIG
)
my_message
(
ER_TRANS_CACHE_FULL
,
ER
(
ER_TRANS_CACHE_FULL
),
MYF
(
MY_WME
));
else
my_error
(
ER_ERROR_ON_WRITE
,
MYF
(
MY_WME
),
name
,
errno
);
DBUG_VOID_RETURN
;
}
bool
MYSQL_BIN_LOG
::
check_write_error
(
THD
*
thd
)
{
DBUG_ENTER
(
"MYSQL_BIN_LOG::check_write_error"
);
bool
checked
=
FALSE
;
if
(
!
thd
->
is_error
())
DBUG_RETURN
(
checked
);
switch
(
thd
->
main_da
.
sql_errno
())
{
case
ER_TRANS_CACHE_FULL
:
case
ER_ERROR_ON_WRITE
:
case
ER_BINLOG_LOGGING_IMPOSSIBLE
:
checked
=
TRUE
;
break
;
}
DBUG_RETURN
(
checked
);
}
/**
@note
How do we handle this (unlikely but legal) case:
...
...
@@ -3854,6 +3922,7 @@ MYSQL_BIN_LOG::flush_and_set_pending_rows_event(THD *thd,
if
(
pending
->
write
(
file
))
{
pthread_mutex_unlock
(
&
LOCK_log
);
set_write_error
(
thd
);
DBUG_RETURN
(
1
);
}
...
...
@@ -3928,7 +3997,8 @@ bool MYSQL_BIN_LOG::write(Log_event *event_info)
*/
bool
const
end_stmt
=
thd
->
prelocked_mode
&&
thd
->
lex
->
requires_prelocking
();
thd
->
binlog_flush_pending_rows_event
(
end_stmt
);
if
(
thd
->
binlog_flush_pending_rows_event
(
end_stmt
))
DBUG_RETURN
(
error
);
pthread_mutex_lock
(
&
LOCK_log
);
...
...
@@ -3979,8 +4049,7 @@ bool MYSQL_BIN_LOG::write(Log_event *event_info)
DBUG_PRINT
(
"info"
,
(
"Using trans_log: cache: %d, trans_log_pos: %lu"
,
event_info
->
get_cache_stmt
(),
(
ulong
)
trans_log_pos
));
if
(
trans_log_pos
==
0
)
thd
->
binlog_start_trans_and_stmt
();
thd
->
binlog_start_trans_and_stmt
();
file
=
trans_log
;
}
/*
...
...
@@ -4058,7 +4127,8 @@ bool MYSQL_BIN_LOG::write(Log_event *event_info)
Write the SQL command
*/
if
(
event_info
->
write
(
file
))
if
(
event_info
->
write
(
file
)
||
DBUG_EVALUATE_IF
(
"injecting_fault_writing"
,
1
,
0
))
goto
err
;
if
(
file
==
&
log_file
)
// we are writing to the real log (disk)
...
...
@@ -4072,13 +4142,7 @@ bool MYSQL_BIN_LOG::write(Log_event *event_info)
err:
if
(
error
)
{
if
(
my_errno
==
EFBIG
)
my_message
(
ER_TRANS_CACHE_FULL
,
ER
(
ER_TRANS_CACHE_FULL
),
MYF
(
0
));
else
my_error
(
ER_ERROR_ON_WRITE
,
MYF
(
0
),
name
,
errno
);
write_error
=
1
;
}
set_write_error
(
thd
);
}
if
(
event_info
->
flags
&
LOG_EVENT_UPDATE_TABLE_MAP_VERSION_F
)
...
...
@@ -4359,6 +4423,29 @@ int query_error_code(THD *thd, bool not_killed)
return
error
;
}
bool
MYSQL_BIN_LOG
::
write_incident
(
THD
*
thd
,
bool
lock
)
{
uint
error
=
0
;
DBUG_ENTER
(
"MYSQL_BIN_LOG::write_incident"
);
LEX_STRING
const
write_error_msg
=
{
C_STRING_WITH_LEN
(
"error writing to the binary log"
)
};
Incident
incident
=
INCIDENT_LOST_EVENTS
;
Incident_log_event
ev
(
thd
,
incident
,
write_error_msg
);
if
(
lock
)
pthread_mutex_lock
(
&
LOCK_log
);
ev
.
write
(
&
log_file
);
if
(
lock
)
{
if
(
!
error
&&
!
(
error
=
flush_and_sync
()))
{
signal_update
();
rotate_and_purge
(
RP_LOCK_LOG_IS_ALREADY_LOCKED
);
}
pthread_mutex_unlock
(
&
LOCK_log
);
}
DBUG_RETURN
(
error
);
}
/**
Write a cached log entry to the binary log.
- To support transaction over replication, we wrap the transaction
...
...
@@ -4371,6 +4458,9 @@ int query_error_code(THD *thd, bool not_killed)
@param cache The cache to copy to the binlog
@param commit_event The commit event to print after writing the
contents of the cache.
@param incident Defines if an incident event should be created to
notify that some non-transactional changes did
not get into the binlog.
@note
We only come here if there is something in the cache.
...
...
@@ -4380,7 +4470,8 @@ int query_error_code(THD *thd, bool not_killed)
'cache' needs to be reinitialized after this functions returns.
*/
bool
MYSQL_BIN_LOG
::
write
(
THD
*
thd
,
IO_CACHE
*
cache
,
Log_event
*
commit_event
)
bool
MYSQL_BIN_LOG
::
write
(
THD
*
thd
,
IO_CACHE
*
cache
,
Log_event
*
commit_event
,
bool
incident
)
{
DBUG_ENTER
(
"MYSQL_BIN_LOG::write(THD *, IO_CACHE *, Log_event *)"
);
VOID
(
pthread_mutex_lock
(
&
LOCK_log
));
...
...
@@ -4429,6 +4520,10 @@ bool MYSQL_BIN_LOG::write(THD *thd, IO_CACHE *cache, Log_event *commit_event)
if
(
commit_event
&&
commit_event
->
write
(
&
log_file
))
goto
err
;
if
(
incident
&&
write_incident
(
thd
,
FALSE
))
goto
err
;
if
(
flush_and_sync
())
goto
err
;
DBUG_EXECUTE_IF
(
"half_binlogged_transaction"
,
abort
(););
...
...
sql/log.h
View file @
16ead297
...
...
@@ -356,9 +356,12 @@ public:
void
new_file
();
bool
write
(
Log_event
*
event_info
);
// binary log write
bool
write
(
THD
*
thd
,
IO_CACHE
*
cache
,
Log_event
*
commit_event
);
bool
write
(
THD
*
thd
,
IO_CACHE
*
cache
,
Log_event
*
commit_event
,
bool
incident
);
bool
write_incident
(
THD
*
thd
,
bool
lock
);
int
write_cache
(
IO_CACHE
*
cache
,
bool
lock_log
,
bool
flush_and_sync
);
void
set_write_error
(
THD
*
thd
);
bool
check_write_error
(
THD
*
thd
);
void
start_union_events
(
THD
*
thd
,
query_id_t
query_id_param
);
void
stop_union_events
(
THD
*
thd
);
...
...
sql/sql_delete.cc
View file @
16ead297
...
...
@@ -408,7 +408,7 @@ cleanup:
thd
->
query
,
thd
->
query_length
,
is_trans
,
FALSE
,
errcode
);
if
(
log_result
&&
transactional_table
)
if
(
log_result
)
{
error
=
1
;
}
...
...
sql/sql_insert.cc
View file @
16ead297
...
...
@@ -896,8 +896,7 @@ bool mysql_insert(THD *thd,TABLE_LIST *table_list,
if
(
thd
->
binlog_query
(
THD
::
ROW_QUERY_TYPE
,
thd
->
query
,
thd
->
query_length
,
transactional_table
,
FALSE
,
errcode
)
&&
transactional_table
)
errcode
))
{
error
=
1
;
}
...
...
sql/sql_update.cc
View file @
16ead297
...
...
@@ -803,8 +803,7 @@ int mysql_update(THD *thd,
if
(
thd
->
binlog_query
(
THD
::
ROW_QUERY_TYPE
,
thd
->
query
,
thd
->
query_length
,
transactional_table
,
FALSE
,
errcode
)
&&
transactional_table
)
transactional_table
,
FALSE
,
errcode
))
{
error
=
1
;
// Rollback update
}
...
...
@@ -2087,8 +2086,7 @@ bool multi_update::send_eof()
errcode
=
query_error_code
(
thd
,
killed_status
==
THD
::
NOT_KILLED
);
if
(
thd
->
binlog_query
(
THD
::
ROW_QUERY_TYPE
,
thd
->
query
,
thd
->
query_length
,
transactional_tables
,
FALSE
,
errcode
)
&&
trans_safe
)
transactional_tables
,
FALSE
,
errcode
))
{
local_error
=
1
;
// Rollback update
}
...
...
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