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
b9dcd3b1
Commit
b9dcd3b1
authored
Mar 11, 2006
by
tomas@poseidon.ndb.mysql.com
Browse files
Options
Browse Files
Download
Plain Diff
Merge tulin@bk-internal.mysql.com:/home/bk/mysql-5.1-new
into poseidon.ndb.mysql.com:/home/tomas/mysql-5.1-new
parents
897a886f
a7e7a1ac
Changes
20
Hide whitespace changes
Inline
Side-by-side
Showing
20 changed files
with
230 additions
and
213 deletions
+230
-213
mysql-test/r/ndb_binlog_basic.result
mysql-test/r/ndb_binlog_basic.result
+0
-11
mysql-test/r/ndb_binlog_ddl_multi.result
mysql-test/r/ndb_binlog_ddl_multi.result
+14
-41
mysql-test/r/ndb_binlog_ignore_db.result
mysql-test/r/ndb_binlog_ignore_db.result
+0
-2
mysql-test/r/ndb_binlog_multi.result
mysql-test/r/ndb_binlog_multi.result
+0
-2
mysql-test/r/rpl_ndb_charset.result
mysql-test/r/rpl_ndb_charset.result
+0
-10
mysql-test/r/rpl_ndb_dd_basic.result
mysql-test/r/rpl_ndb_dd_basic.result
+13
-14
mysql-test/r/rpl_ndb_log.result
mysql-test/r/rpl_ndb_log.result
+38
-38
mysql-test/t/disabled.def
mysql-test/t/disabled.def
+4
-3
mysql-test/t/ndb_binlog_basic.test
mysql-test/t/ndb_binlog_basic.test
+0
-4
mysql-test/t/ndb_binlog_ddl_multi.test
mysql-test/t/ndb_binlog_ddl_multi.test
+1
-2
mysql-test/t/ndb_binlog_ignore_db.test
mysql-test/t/ndb_binlog_ignore_db.test
+1
-6
mysql-test/t/ndb_binlog_multi.test
mysql-test/t/ndb_binlog_multi.test
+1
-0
mysql-test/t/rpl_ndb_dd_basic.test
mysql-test/t/rpl_ndb_dd_basic.test
+1
-4
sql/ha_ndbcluster_binlog.cc
sql/ha_ndbcluster_binlog.cc
+117
-69
sql/rpl_injector.cc
sql/rpl_injector.cc
+3
-0
sql/rpl_injector.h
sql/rpl_injector.h
+5
-0
storage/ndb/src/kernel/blocks/dbdict/Dbdict.cpp
storage/ndb/src/kernel/blocks/dbdict/Dbdict.cpp
+1
-1
storage/ndb/src/kernel/blocks/suma/Suma.cpp
storage/ndb/src/kernel/blocks/suma/Suma.cpp
+9
-0
storage/ndb/src/ndbapi/NdbEventOperationImpl.cpp
storage/ndb/src/ndbapi/NdbEventOperationImpl.cpp
+18
-4
storage/ndb/src/ndbapi/NdbEventOperationImpl.hpp
storage/ndb/src/ndbapi/NdbEventOperationImpl.hpp
+4
-2
No files found.
mysql-test/r/ndb_binlog_basic.result
View file @
b9dcd3b1
...
...
@@ -29,12 +29,6 @@ select inserts,updates,deletes from
cluster.binlog_index where epoch > @max_epoch and updates > 0;
inserts updates deletes
2 1 1
select schemaops from
cluster.binlog_index where epoch > @max_epoch and schemaops > 0;
schemaops
1
1
1
flush logs;
purge master logs before now();
select count(*) from cluster.binlog_index;
...
...
@@ -55,8 +49,3 @@ select inserts,updates,deletes from
cluster.binlog_index where epoch > @max_epoch and inserts > 0;
inserts updates deletes
2 0 0
select schemaops from
cluster.binlog_index where epoch > @max_epoch and schemaops > 0;
schemaops
1
1
mysql-test/r/ndb_binlog_ddl_multi.result
View file @
b9dcd3b1
...
...
@@ -23,10 +23,6 @@ reset master;
alter table t2 add column (b int);
show binlog events from <binlog_start>;
Log_name Pos Event_type Server_id End_log_pos Info
master-bin1.000001 # Query # # BEGIN
master-bin1.000001 # Table_map # # cluster.apply_status
master-bin1.000001 # Write_rows # #
master-bin1.000001 # Query # # COMMIT
master-bin1.000001 # Query # # use `test`; alter table t2 add column (b int)
reset master;
reset master;
...
...
@@ -35,10 +31,6 @@ drop table mysqltest.t1;
show binlog events from <binlog_start>;
Log_name Pos Event_type Server_id End_log_pos Info
master-bin.000001 # Query # # ALTER DATABASE mysqltest CHARACTER SET latin1
master-bin.000001 # Query # # BEGIN
master-bin.000001 # Table_map # # cluster.apply_status
master-bin.000001 # Write_rows # #
master-bin.000001 # Query # # COMMIT
master-bin.000001 # Query # # use `mysqltest`; drop table `t1`
reset master;
reset master;
...
...
@@ -49,10 +41,10 @@ create table t1 (a int primary key) engine=ndb;
show binlog events from <binlog_start>;
Log_name Pos Event_type Server_id End_log_pos Info
master-bin1.000001 # Query # # BEGIN
master-bin1.000001 # Table_map # #
cluster.apply_status
master-bin1.000001 #
Write_rows # #
master-bin1.000001 #
Table_map # # test.t2
master-bin1.000001 # Write_rows # #
master-bin1.000001 # Table_map # #
table_id: # (test.t2)
master-bin1.000001 #
Table_map # # table_id: # (cluster.apply_status)
master-bin1.000001 #
Write_rows # # table_id: #
master-bin1.000001 # Write_rows # #
table_id: # flags: STMT_END_F
master-bin1.000001 # Query # # COMMIT
master-bin1.000001 # Query # # drop database mysqltest
master-bin1.000001 # Query # # use `test`; create table t1 (a int primary key) engine=ndb
...
...
@@ -118,10 +110,6 @@ master-bin1.000001 # Query # # DROP TABLESPACE ts1
ENGINE = NDB
master-bin1.000001 # Query # # DROP LOGFILE GROUP lg1
ENGINE =NDB
master-bin1.000001 # Query # # BEGIN
master-bin1.000001 # Table_map # # cluster.apply_status
master-bin1.000001 # Write_rows # #
master-bin1.000001 # Query # # COMMIT
master-bin1.000001 # Query # # use `test`; drop table `t1`
reset master;
show tables;
...
...
@@ -138,25 +126,9 @@ Log_name Pos Event_type Server_id End_log_pos Info
master-bin1.000001 # Query # # use `test`; create table t1 (a int key) engine=ndb
master-bin1.000001 # Query # # use `test`; create table t2 (a int key) engine=ndb
master-bin1.000001 # Query # # use `test`; create table t3 (a int key) engine=ndb
master-bin1.000001 # Query # # BEGIN
master-bin1.000001 # Table_map # # cluster.apply_status
master-bin1.000001 # Write_rows # #
master-bin1.000001 # Query # # COMMIT
master-bin1.000001 # Query # # use `test`; rename table `test.t3` to `test.t4`
master-bin1.000001 # Query # # BEGIN
master-bin1.000001 # Table_map # # cluster.apply_status
master-bin1.000001 # Write_rows # #
master-bin1.000001 # Query # # COMMIT
master-bin1.000001 # Query # # use `test`; rename table `test.t2` to `test.t3`
master-bin1.000001 # Query # # BEGIN
master-bin1.000001 # Table_map # # cluster.apply_status
master-bin1.000001 # Write_rows # #
master-bin1.000001 # Query # # COMMIT
master-bin1.000001 # Query # # use `test`; rename table `test.t1` to `test.t2`
master-bin1.000001 # Query # # BEGIN
master-bin1.000001 # Table_map # # cluster.apply_status
master-bin1.000001 # Write_rows # #
master-bin1.000001 # Query # # COMMIT
master-bin1.000001 # Query # # use `test`; rename table `test.t4` to `test.t1`
drop table t1;
drop table t2;
...
...
@@ -171,20 +143,21 @@ create table t1 (a int key) engine=ndb;
insert into t1 values(1);
rename table t1 to t2;
insert into t2 values(2);
drop table t2;
show binlog events from <binlog_start>;
Log_name Pos Event_type Server_id End_log_pos Info
master-bin1.000001 # Query # # use `test`; create table t1 (a int key) engine=ndb
master-bin1.000001 # Query # # BEGIN
master-bin1.000001 # Table_map # #
cluster.apply_status
master-bin1.000001 #
Write_rows # #
master-bin1.000001 #
Table_map # # test.t1
master-bin1.000001 # Write_rows # #
master-bin1.000001 # Table_map # #
table_id: # (test.t1)
master-bin1.000001 #
Table_map # # table_id: # (cluster.apply_status)
master-bin1.000001 #
Write_rows # # table_id: #
master-bin1.000001 # Write_rows # #
table_id: # flags: STMT_END_F
master-bin1.000001 # Query # # COMMIT
master-bin1.000001 # Query # # use `test`; rename table `test.t1` to `test.t2`
master-bin1.000001 # Query # # BEGIN
master-bin1.000001 # Table_map # #
cluster.apply_status
master-bin1.000001 #
Write_rows # #
master-bin1.000001 #
Table_map # # test.t2
master-bin1.000001 # Write_rows # #
master-bin1.000001 # Table_map # #
table_id: # (test.t2)
master-bin1.000001 #
Table_map # # table_id: # (cluster.apply_status)
master-bin1.000001 #
Write_rows # # table_id: #
master-bin1.000001 # Write_rows # #
table_id: # flags: STMT_END_F
master-bin1.000001 # Query # # COMMIT
drop table t2;
master-bin1.000001 # Query # # use `test`; drop table `t2`
mysql-test/r/ndb_binlog_ignore_db.result
View file @
b9dcd3b1
...
...
@@ -9,6 +9,4 @@ Log_name Pos Event_type Server_id End_log_pos Info
master-bin.000001 # Query # # use `test`; drop table if exists t1
master-bin.000001 # Table_map # # table_id: # (mysql.proc)
master-bin.000001 # Write_rows # # table_id: # flags: STMT_END_F
master-bin.000001 # Table_map # # table_id: # (mysql.event)
master-bin.000001 # Write_rows # # table_id: # flags: STMT_END_F
drop database mysqltest;
mysql-test/r/ndb_binlog_multi.result
View file @
b9dcd3b1
...
...
@@ -33,11 +33,9 @@ cluster.binlog_index ORDER BY epoch DESC LIMIT 1;
SELECT inserts,updates,deletes,schemaops FROM
cluster.binlog_index WHERE epoch > <the_epoch> AND epoch < <the_epoch2>;
inserts updates deletes schemaops
0 0 0 1
drop table t1;
SHOW TABLES;
Tables_in_test
SELECT inserts,updates,deletes,schemaops FROM
cluster.binlog_index WHERE epoch > <the_epoch> AND epoch < <the_epoch2>;
inserts updates deletes schemaops
0 0 0 1
mysql-test/r/rpl_ndb_charset.result
View file @
b9dcd3b1
...
...
@@ -114,20 +114,14 @@ Log_name Pos Event_type Server_id End_log_pos Info
master-bin.000001 # Query 1 # drop database if exists mysqltest2
master-bin.000001 # Table_map 1 # table_id: # (mysql.proc)
master-bin.000001 # Write_rows 1 # table_id: # flags: STMT_END_F
master-bin.000001 # Table_map 1 # table_id: # (mysql.event)
master-bin.000001 # Write_rows 1 # table_id: # flags: STMT_END_F
master-bin.000001 # Query 1 # drop database if exists mysqltest3
master-bin.000001 # Table_map 1 # table_id: # (mysql.proc)
master-bin.000001 # Write_rows 1 # table_id: # flags: STMT_END_F
master-bin.000001 # Table_map 1 # table_id: # (mysql.event)
master-bin.000001 # Write_rows 1 # table_id: # flags: STMT_END_F
master-bin.000001 # Query 1 # create database mysqltest2 character set latin2
master-bin.000001 # Query 1 # create database mysqltest3
master-bin.000001 # Query 1 # drop database mysqltest3
master-bin.000001 # Table_map 1 # table_id: # (mysql.proc)
master-bin.000001 # Write_rows 1 # table_id: # flags: STMT_END_F
master-bin.000001 # Table_map 1 # table_id: # (mysql.event)
master-bin.000001 # Write_rows 1 # table_id: # flags: STMT_END_F
master-bin.000001 # Query 1 # create database mysqltest3
master-bin.000001 # Query 1 # use `mysqltest2`; create table t1 (a int auto_increment primary key, b varchar(100))
master-bin.000001 # Table_map 1 # table_id: # (mysqltest2.t1)
...
...
@@ -155,13 +149,9 @@ master-bin.000001 # Write_rows 1 # table_id: # flags: STMT_END_F
master-bin.000001 # Query 1 # drop database mysqltest2
master-bin.000001 # Table_map 1 # table_id: # (mysql.proc)
master-bin.000001 # Write_rows 1 # table_id: # flags: STMT_END_F
master-bin.000001 # Table_map 1 # table_id: # (mysql.event)
master-bin.000001 # Write_rows 1 # table_id: # flags: STMT_END_F
master-bin.000001 # Query 1 # drop database mysqltest3
master-bin.000001 # Table_map 1 # table_id: # (mysql.proc)
master-bin.000001 # Write_rows 1 # table_id: # flags: STMT_END_F
master-bin.000001 # Table_map 1 # table_id: # (mysql.event)
master-bin.000001 # Write_rows 1 # table_id: # flags: STMT_END_F
select "--- --global--" as "";
--- --global--
...
...
mysql-test/r/rpl_ndb_dd_basic.result
View file @
b9dcd3b1
...
...
@@ -32,36 +32,35 @@ pk1 b c
select * from t1 order by pk1;
pk1 b c
1 2 3
show binlog events;
show binlog events
from <binlog_start>
;
Log_name Pos Event_type Server_id End_log_pos Info
master-bin.000001 4 Format_desc 1 102 Server ver: VERSION, Binlog ver: 4
master-bin.000001 102 Query 1 188 use `test`; DROP TABLE IF EXISTS t1
master-bin.000001 188 Query 1 353 CREATE LOGFILE GROUP lg1
master-bin.000001 # Query # # use `test`; DROP TABLE IF EXISTS t1
master-bin.000001 # Query # # CREATE LOGFILE GROUP lg1
ADD UNDOFILE 'undofile.dat'
INITIAL_SIZE 16M
UNDO_BUFFER_SIZE = 1M
ENGINE=NDB
master-bin.000001
353 Query 1 496
alter logfile group lg1
master-bin.000001
# Query # #
alter logfile group lg1
add undofile 'undofile02.dat'
initial_size 4M engine=ndb
master-bin.000001
496 Query 1 658
CREATE TABLESPACE ts1
master-bin.000001
# Query # #
CREATE TABLESPACE ts1
ADD DATAFILE 'datafile.dat'
USE LOGFILE GROUP lg1
INITIAL_SIZE 12M
ENGINE NDB
master-bin.000001
658 Query 1 798
alter tablespace ts1
master-bin.000001
# Query # #
alter tablespace ts1
add datafile 'datafile02.dat'
initial_size 4M engine=ndb
master-bin.000001
798 Query 1 978
use `test`; CREATE TABLE t1
master-bin.000001
# Query # #
use `test`; CREATE TABLE t1
(pk1 int not null primary key, b int not null, c int not null)
tablespace ts1 storage disk
engine ndb
master-bin.000001
978 Query 1 1042
BEGIN
master-bin.000001
1042 Table_map 1 41
table_id: # (test.t1)
master-bin.000001
1083 Table_map 1 94
table_id: # (cluster.apply_status)
master-bin.000001
1136 Write_rows 1 136
table_id: #
master-bin.000001
1178 Write_rows 1 178
table_id: # flags: STMT_END_F
master-bin.000001
1220 Query 1 1285
COMMIT
master-bin.000001
# Query # #
BEGIN
master-bin.000001
# Table_map # #
table_id: # (test.t1)
master-bin.000001
# Table_map # #
table_id: # (cluster.apply_status)
master-bin.000001
# Write_rows # #
table_id: #
master-bin.000001
# Write_rows # #
table_id: # flags: STMT_END_F
master-bin.000001
# Query # #
COMMIT
drop table t1;
alter tablespace ts1
drop datafile 'datafile.dat'
...
...
mysql-test/r/rpl_ndb_log.result
View file @
b9dcd3b1
...
...
@@ -21,18 +21,18 @@ Log_name Pos Event_type Server_id End_log_pos Info
master-bin.000001 # Format_desc 1 # Server ver: VERSION, Binlog ver: 4
master-bin.000001 # Query 1 # use `test`; create table t1(n int not null auto_increment primary key)ENGINE=NDB
master-bin.000001 # Query 1 # BEGIN
master-bin.000001 # Table_map 1 #
cluster.apply_status
master-bin.000001 #
Write_rows 1 #
master-bin.000001 #
Table_map 1 # test.t1
master-bin.000001 # Write_rows 1 #
master-bin.000001 # Table_map 1 #
table_id: # (test.t1)
master-bin.000001 #
Table_map 1 # table_id: # (cluster.apply_status)
master-bin.000001 #
Write_rows 1 # table_id: #
master-bin.000001 # Write_rows 1 #
table_id: # flags: STMT_END_F
master-bin.000001 # Query 1 # COMMIT
master-bin.000001 # Query 1 # use `test`; drop table t1
master-bin.000001 # Query 1 # use `test`; create table t1 (word char(20) not null)ENGINE=NDB
master-bin.000001 # Query 1 # BEGIN
master-bin.000001 # Table_map 1 #
cluster.apply_status
master-bin.000001 #
Write_rows 1 #
master-bin.000001 #
Table_map 1 # test.t1
master-bin.000001 # Write_rows 1 #
master-bin.000001 # Table_map 1 #
table_id: # (test.t1)
master-bin.000001 #
Table_map 1 # table_id: # (cluster.apply_status)
master-bin.000001 #
Write_rows 1 # table_id: #
master-bin.000001 # Write_rows 1 #
table_id: # flags: STMT_END_F
master-bin.000001 # Query 1 # COMMIT
show binlog events from 102 limit 1;
Log_name Pos Event_type Server_id End_log_pos Info
...
...
@@ -43,7 +43,7 @@ master-bin.000001 # Query 1 # use `test`; create table t1(n int not null auto_in
master-bin.000001 # Query 1 # BEGIN
show binlog events from 102 limit 2,1;
Log_name Pos Event_type Server_id End_log_pos Info
master-bin.000001 # Table_map 1 #
cluster.apply_status
master-bin.000001 # Table_map 1 #
table_id: # (test.t1)
flush logs;
create table t3 (a int)ENGINE=NDB;
start slave;
...
...
@@ -56,18 +56,18 @@ Log_name Pos Event_type Server_id End_log_pos Info
master-bin.000001 # Format_desc 1 # Server ver: VERSION, Binlog ver: 4
master-bin.000001 # Query 1 # use `test`; create table t1(n int not null auto_increment primary key)ENGINE=NDB
master-bin.000001 # Query 1 # BEGIN
master-bin.000001 # Table_map 1 #
cluster.apply_status
master-bin.000001 #
Write_rows 1 #
master-bin.000001 #
Table_map 1 # test.t1
master-bin.000001 # Write_rows 1 #
master-bin.000001 # Table_map 1 #
table_id: # (test.t1)
master-bin.000001 #
Table_map 1 # table_id: # (cluster.apply_status)
master-bin.000001 #
Write_rows 1 # table_id: #
master-bin.000001 # Write_rows 1 #
table_id: # flags: STMT_END_F
master-bin.000001 # Query 1 # COMMIT
master-bin.000001 # Query 1 # use `test`; drop table t1
master-bin.000001 # Query 1 # use `test`; create table t1 (word char(20) not null)ENGINE=NDB
master-bin.000001 # Query 1 # BEGIN
master-bin.000001 # Table_map 1 #
cluster.apply_status
master-bin.000001 #
Write_rows 1 #
master-bin.000001 #
Table_map 1 # test.t1
master-bin.000001 # Write_rows 1 #
master-bin.000001 # Table_map 1 #
table_id: # (test.t1)
master-bin.000001 #
Table_map 1 # table_id: # (cluster.apply_status)
master-bin.000001 #
Write_rows 1 # table_id: #
master-bin.000001 # Write_rows 1 #
table_id: # flags: STMT_END_F
master-bin.000001 # Query 1 # COMMIT
master-bin.000001 # Rotate 1 # master-bin.000002;pos=4
show binlog events in 'master-bin.000002';
...
...
@@ -76,53 +76,53 @@ master-bin.000002 # Format_desc 1 # Server ver: VERSION, Binlog ver: 4
master-bin.000002 # Query 1 # use `test`; create table t3 (a int)ENGINE=NDB
master-bin.000002 # Query 1 # use `test`; create table t2 (n int)ENGINE=NDB
master-bin.000002 # Query 1 # BEGIN
master-bin.000002 # Table_map 1 #
cluster.apply_status
master-bin.000002 #
Write_rows 1 #
master-bin.000002 #
Table_map 1 # test.t2
master-bin.000002 # Write_rows 1 #
master-bin.000002 # Table_map 1 #
table_id: # (test.t2)
master-bin.000002 #
Table_map 1 # table_id: # (cluster.apply_status)
master-bin.000002 #
Write_rows 1 # table_id: #
master-bin.000002 # Write_rows 1 #
table_id: # flags: STMT_END_F
master-bin.000002 # Query 1 # COMMIT
show binary logs;
Log_name File_size
master-bin.000001 1
722
master-bin.000002
603
master-bin.000001 1
698
master-bin.000002
591
start slave;
show binary logs;
Log_name File_size
slave-bin.000001 1
817
slave-bin.000001 1
793
slave-bin.000002 198
show binlog events in 'slave-bin.000001' from 4;
Log_name Pos Event_type Server_id End_log_pos Info
slave-bin.000001 # Format_desc 2 # Server ver: VERSION, Binlog ver: 4
slave-bin.000001 # Query 1 # use `test`; create table t1(n int not null auto_increment primary key)ENGINE=NDB
slave-bin.000001 # Query 2 # BEGIN
slave-bin.000001 # Table_map 2 #
cluster.apply_status
slave-bin.000001 #
Write_rows 2 #
slave-bin.000001 #
Table_map 2 # test.t1
slave-bin.000001 # Write_rows 2 #
slave-bin.000001 # Table_map 2 #
table_id: # (test.t1)
slave-bin.000001 #
Table_map 2 # table_id: # (cluster.apply_status)
slave-bin.000001 #
Write_rows 2 # table_id: #
slave-bin.000001 # Write_rows 2 #
table_id: # flags: STMT_END_F
slave-bin.000001 # Query 2 # COMMIT
slave-bin.000001 # Query 1 # use `test`; drop table t1
slave-bin.000001 # Query 1 # use `test`; create table t1 (word char(20) not null)ENGINE=NDB
slave-bin.000001 # Query 1 # use `test`; create table t3 (a int)ENGINE=NDB
slave-bin.000001 # Query 2 # BEGIN
slave-bin.000001 # Table_map 2 #
cluster.apply_status
slave-bin.000001 #
Write_rows 2 #
slave-bin.000001 #
Table_map 2 # test.t1
slave-bin.000001 # Write_rows 2 #
slave-bin.000001 # Table_map 2 #
table_id: # (test.t1)
slave-bin.000001 #
Table_map 2 # table_id: # (cluster.apply_status)
slave-bin.000001 #
Write_rows 2 # table_id: #
slave-bin.000001 # Write_rows 2 #
table_id: # flags: STMT_END_F
slave-bin.000001 # Query 2 # COMMIT
slave-bin.000001 # Query 1 # use `test`; create table t3 (a int)ENGINE=NDB
slave-bin.000001 # Rotate 2 # slave-bin.000002;pos=4
show binlog events in 'slave-bin.000002' from 4;
Log_name Pos Event_type Server_id End_log_pos Info
slave-bin.000002 # Format_desc 2 # Server ver: VERSION, Binlog ver: 4
slave-bin.000002 # Query 1 # use `test`; create table t2 (n int)ENGINE=NDB
slave-bin.000002 # Query 2 # BEGIN
slave-bin.000002 # Table_map 2 #
cluster.apply_status
slave-bin.000002 #
Write_rows 2 #
slave-bin.000002 #
Table_map 2 # test.t2
slave-bin.000002 # Write_rows 2 #
slave-bin.000002 # Table_map 2 #
table_id: # (test.t2)
slave-bin.000002 #
Table_map 2 # table_id: # (cluster.apply_status)
slave-bin.000002 #
Write_rows 2 # table_id: #
slave-bin.000002 # Write_rows 2 #
table_id: # flags: STMT_END_F
slave-bin.000002 # Query 2 # COMMIT
show slave status;
Slave_IO_State Master_Host Master_User Master_Port Connect_Retry Master_Log_File Read_Master_Log_Pos Relay_Log_File Relay_Log_Pos Relay_Master_Log_File Slave_IO_Running Slave_SQL_Running Replicate_Do_DB Replicate_Ignore_DB Replicate_Do_Table Replicate_Ignore_Table Replicate_Wild_Do_Table Replicate_Wild_Ignore_Table Last_Errno Last_Error Skip_Counter Exec_Master_Log_Pos Relay_Log_Space Until_Condition Until_Log_File Until_Log_Pos Master_SSL_Allowed Master_SSL_CA_File Master_SSL_CA_Path Master_SSL_Cert Master_SSL_Cipher Master_SSL_Key Seconds_Behind_Master
# 127.0.0.1 root MASTER_PORT 1 master-bin.000002
603 # # master-bin.000002 Yes Yes # 0 0 603
# None 0 No #
# 127.0.0.1 root MASTER_PORT 1 master-bin.000002
591 # # master-bin.000002 Yes Yes # 0 0 591
# None 0 No #
show binlog events in 'slave-bin.000005' from 4;
ERROR HY000: Error when executing command SHOW BINLOG EVENTS: Could not find target log
DROP TABLE t1;
...
...
mysql-test/t/disabled.def
View file @
b9dcd3b1
...
...
@@ -15,8 +15,9 @@ events : test case unstable. andrey will fix
#ndb_alter_table_row : sometimes wrong error 1015!=1046
ndb_autodiscover : Needs to be fixed w.r.t binlog
ndb_autodiscover2 : Needs to be fixed w.r.t binlog
ndb_binlog_basic : Results are not deterministic, Tomas will fix
ndb_binlog_ddl_multi : Bug#17038 [PATCH PENDING]
#ndb_binlog_basic : Results are not deterministic, Tomas will fix
#ndb_binlog_ddl_multi : Bug#17038 [PATCH PENDING]
ndb_binlog_multi : Results are not deterministic, Tomas will fix
ndb_load : Bug#17233
partition_03ndb : Bug#16385
ps_7ndb : dbug assert in RBR mode when executing test suite
...
...
@@ -33,7 +34,7 @@ rpl_ndb_delete_nowhere : Bug#17400: delete & update of rows in table without pk
rpl_ndb_innodb2ndb : Bugs#17400: delete & update of rows in table without pk fails
rpl_ndb_insert_ignore : Bugs: #17431: INSERT IGNORE INTO returns failed: 1296
rpl_ndb_myisam2ndb : Bugs#17400: delete & update of rows in table without pk fails
rpl_ndb_log : result not deterministic
#
rpl_ndb_log : result not deterministic
rpl_ndb_relay_space : Bug#16993
rpl_ndb_multi_update2 : BUG#17738 In progress
rpl_ndb_multi_update3 : Bug#17400: delete & update of rows in table without pk fails
...
...
mysql-test/t/ndb_binlog_basic.test
View file @
b9dcd3b1
...
...
@@ -42,8 +42,6 @@ select inserts from cluster.binlog_index where epoch > @max_epoch and inserts >
select
deletes
from
cluster
.
binlog_index
where
epoch
>
@
max_epoch
and
deletes
>
5
;
select
inserts
,
updates
,
deletes
from
cluster
.
binlog_index
where
epoch
>
@
max_epoch
and
updates
>
0
;
select
schemaops
from
cluster
.
binlog_index
where
epoch
>
@
max_epoch
and
schemaops
>
0
;
#
# check that purge clears the binlog_index
...
...
@@ -72,5 +70,3 @@ drop table t1;
drop
database
mysqltest
;
select
inserts
,
updates
,
deletes
from
cluster
.
binlog_index
where
epoch
>
@
max_epoch
and
inserts
>
0
;
select
schemaops
from
cluster
.
binlog_index
where
epoch
>
@
max_epoch
and
schemaops
>
0
;
mysql-test/t/ndb_binlog_ddl_multi.test
View file @
b9dcd3b1
...
...
@@ -171,10 +171,9 @@ create table t1 (a int key) engine=ndb;
insert
into
t1
values
(
1
);
rename
table
t1
to
t2
;
insert
into
t2
values
(
2
);
drop
table
t2
;
# now we should see data in table t1 _and_ t2
# prior to bug fix, data was missing for t2
--
connection
server2
--
source
include
/
show_binlog_events
.
inc
drop
table
t2
;
mysql-test/t/ndb_binlog_ignore_db.test
View file @
b9dcd3b1
--
source
include
/
have_ndb
.
inc
--
source
include
/
have_binlog_format_row
.
inc
--
let
$binlog_start
=
102
--
disable_warnings
drop
table
if
exists
t1
;
drop
database
if
exists
mysqltest
;
...
...
@@ -12,9 +10,6 @@ create database mysqltest;
use
mysqltest
;
create
table
t1
(
a
int
primary
key
,
b
int
)
engine
=
ndb
;
insert
into
t1
values
(
1
,
1
);
--
replace_result
$binlog_start
<
binlog_start
>
--
replace_column
2
# 4 # 5 #
--
replace_regex
/
table_id
:
[
0
-
9
]
+/
table_id
:
#/
--
eval
show
binlog
events
from
$binlog_start
--
source
include
/
show_binlog_events
.
inc
drop
database
mysqltest
;
mysql-test/t/ndb_binlog_multi.test
View file @
b9dcd3b1
...
...
@@ -43,6 +43,7 @@ SELECT * FROM t2 ORDER BY a;
eval
SELECT
inserts
,
updates
,
deletes
,
schemaops
FROM
cluster
.
binlog_index
WHERE
epoch
=
$the_epoch
;
# single schema ops will not show
# drop the table on server1
DROP
TABLE
t2
;
CREATE
TABLE
t1
(
a
INT
PRIMARY
KEY
)
ENGINE
=
NDB
;
...
...
mysql-test/t/rpl_ndb_dd_basic.test
View file @
b9dcd3b1
...
...
@@ -67,10 +67,7 @@ select * from t1 order by pk1;
#
--
connection
master
let
$VERSION
=
`select version()`
;
--
replace_result
$VERSION
VERSION
--
replace_regex
/
table_id
:
[
0
-
9
]
+/
table_id
:
#/
show
binlog
events
;
--
source
include
/
show_binlog_events
.
inc
#
# cleanup
...
...
sql/ha_ndbcluster_binlog.cc
View file @
b9dcd3b1
...
...
@@ -2659,7 +2659,8 @@ ndb_binlog_thread_handle_data_event(Ndb *ndb, NdbEventOperation *pOp,
return
0
;
TABLE
*
table
=
share
->
table
;
assert
(
table
!=
0
);
DBUG_ASSERT
(
trans
.
good
());
DBUG_ASSERT
(
table
!=
0
);
dbug_print_table
(
"table"
,
table
);
...
...
@@ -2689,7 +2690,7 @@ ndb_binlog_thread_handle_data_event(Ndb *ndb, NdbEventOperation *pOp,
{
case
NDBEVENT
:
:
TE_INSERT
:
row
.
n_inserts
++
;
DBUG_PRINT
(
"info"
,
(
"INSERT INTO %s
"
,
share
->
key
));
DBUG_PRINT
(
"info"
,
(
"INSERT INTO %s
.%s"
,
table_s
->
db
.
str
,
table_s
->
table_name
.
str
));
{
if
(
share
->
flags
&
NSF_BLOB_FLAG
)
{
...
...
@@ -2700,13 +2701,14 @@ ndb_binlog_thread_handle_data_event(Ndb *ndb, NdbEventOperation *pOp,
DBUG_ASSERT
(
ret
==
0
);
}
ndb_unpack_record
(
table
,
share
->
ndb_value
[
0
],
&
b
,
table
->
record
[
0
]);
trans
.
write_row
(
::
server_id
,
injector
::
transaction
::
table
(
table
,
true
),
&
b
,
n_fields
,
table
->
record
[
0
]);
int
ret
=
trans
.
write_row
(
::
server_id
,
injector
::
transaction
::
table
(
table
,
true
),
&
b
,
n_fields
,
table
->
record
[
0
]);
DBUG_ASSERT
(
ret
==
0
);
}
break
;
case
NDBEVENT
:
:
TE_DELETE
:
row
.
n_deletes
++
;
DBUG_PRINT
(
"info"
,(
"DELETE FROM %s
"
,
share
->
key
));
DBUG_PRINT
(
"info"
,(
"DELETE FROM %s
.%s"
,
table_s
->
db
.
str
,
table_s
->
table_name
.
str
));
{
/*
table->record[0] contains only the primary key in this case
...
...
@@ -2735,13 +2737,14 @@ ndb_binlog_thread_handle_data_event(Ndb *ndb, NdbEventOperation *pOp,
}
ndb_unpack_record
(
table
,
share
->
ndb_value
[
n
],
&
b
,
table
->
record
[
n
]);
DBUG_EXECUTE
(
"info"
,
print_records
(
table
,
table
->
record
[
n
]););
trans
.
delete_row
(
::
server_id
,
injector
::
transaction
::
table
(
table
,
true
),
&
b
,
n_fields
,
table
->
record
[
n
]);
int
ret
=
trans
.
delete_row
(
::
server_id
,
injector
::
transaction
::
table
(
table
,
true
),
&
b
,
n_fields
,
table
->
record
[
n
]);
DBUG_ASSERT
(
ret
==
0
);
}
break
;
case
NDBEVENT
:
:
TE_UPDATE
:
row
.
n_updates
++
;
DBUG_PRINT
(
"info"
,
(
"UPDATE %s
"
,
share
->
key
));
DBUG_PRINT
(
"info"
,
(
"UPDATE %s
.%s"
,
table_s
->
db
.
str
,
table_s
->
table_name
.
str
));
{
if
(
share
->
flags
&
NSF_BLOB_FLAG
)
{
...
...
@@ -2779,11 +2782,12 @@ ndb_binlog_thread_handle_data_event(Ndb *ndb, NdbEventOperation *pOp,
}
ndb_unpack_record
(
table
,
share
->
ndb_value
[
1
],
&
b
,
table
->
record
[
1
]);
DBUG_EXECUTE
(
"info"
,
print_records
(
table
,
table
->
record
[
1
]););
trans
.
update_row
(
::
server_id
,
injector
::
transaction
::
table
(
table
,
true
),
&
b
,
n_fields
,
table
->
record
[
1
],
// before values
table
->
record
[
0
]);
// after values
int
ret
=
trans
.
update_row
(
::
server_id
,
injector
::
transaction
::
table
(
table
,
true
),
&
b
,
n_fields
,
table
->
record
[
1
],
// before values
table
->
record
[
0
]);
// after values
DBUG_ASSERT
(
ret
==
0
);
}
}
break
;
...
...
@@ -3059,72 +3063,100 @@ pthread_handler_t ndb_binlog_thread_func(void *arg)
Binlog_index_row
row
;
while
(
pOp
!=
NULL
)
{
gci
=
pOp
->
getGCI
();
DBUG_PRINT
(
"info"
,
(
"Handling gci: %d"
,
(
unsigned
)
gci
));
// sometimes get TE_ALTER with invalid table
DBUG_ASSERT
(
pOp
->
getEventType
()
==
NdbDictionary
::
Event
::
TE_ALTER
||
!
IS_NDB_BLOB_PREFIX
(
pOp
->
getEvent
()
->
getTable
()
->
getName
()));
DBUG_ASSERT
(
gci
<=
ndb_latest_received_binlog_epoch
);
ndb
->
setReportThreshEventGCISlip
(
ndb_report_thresh_binlog_epoch_slip
);
ndb
->
setReportThreshEventFreeMem
(
ndb_report_thresh_binlog_mem_usage
);
assert
(
pOp
->
getGCI
()
<=
ndb_latest_received_binlog_epoch
);
bzero
((
char
*
)
&
row
,
sizeof
(
row
));
injector
::
transaction
trans
=
inj
->
new_trans
(
thd
);
{
// pass table map before epoch
Uint32
iter
=
0
;
const
NdbEventOperation
*
gci_op
;
injector
::
transaction
trans
;
// pass table map before epoch
{
Uint32
iter
=
0
;
const
NdbEventOperation
*
gci_op
;
Uint32
event_types
;
while
((
gci_op
=
ndb
->
getGCIEventOperations
(
&
iter
,
&
event_types
))
!=
NULL
)
while
((
gci_op
=
ndb
->
getGCIEventOperations
(
&
iter
,
&
event_types
))
!=
NULL
)
{
NDB_SHARE
*
share
=
(
NDB_SHARE
*
)
gci_op
->
getCustomData
();
DBUG_PRINT
(
"info"
,
(
"per gci
op %p share %p event types
0x%x"
,
NDB_SHARE
*
share
=
(
NDB_SHARE
*
)
gci_op
->
getCustomData
();
DBUG_PRINT
(
"info"
,
(
"per gci
_op: %p share: %p event_types:
0x%x"
,
gci_op
,
share
,
event_types
));
// workaround for interface returning TE_STOP events
// which are normally filtered out below in the nextEvent loop
if
((
event_types
&
~
NdbDictionary
::
Event
::
TE_STOP
)
==
0
)
{
DBUG_PRINT
(
"info"
,
(
"Skipped TE_STOP on table %s"
,
gci_op
->
getEvent
()
->
getTable
()
->
getName
()));
continue
;
}
// this should not happen
if
(
share
==
NULL
||
share
->
table
==
NULL
)
{
DBUG_PRINT
(
"info"
,
(
"no share or table !"
));
DBUG_PRINT
(
"info"
,
(
"no share or table %s!"
,
gci_op
->
getEvent
()
->
getTable
()
->
getName
()));
continue
;
}
Uint32
const
bits
=
NdbDictionary
::
Event
::
TE_INSERT
|
NdbDictionary
::
Event
::
TE_DELETE
|
NdbDictionary
::
Event
::
TE_UPDATE
;
if
(
event_types
&
bits
)
if
(
share
==
apply_status_share
)
{
// skip this table, it is handled specially
continue
;
}
TABLE
*
table
=
share
->
table
;
const
LEX_STRING
&
name
=
table
->
s
->
table_name
;
if
((
event_types
&
(
NdbDictionary
::
Event
::
TE_INSERT
|
NdbDictionary
::
Event
::
TE_UPDATE
|
NdbDictionary
::
Event
::
TE_DELETE
))
==
0
)
{
DBUG_PRINT
(
"info"
,
(
"skipping non data event table: %.*s"
,
name
.
length
,
name
.
str
));
continue
;
}
if
(
!
trans
.
good
())
{
TABLE
*
table
=
share
->
table
;
const
LEX_STRING
&
name
=
table
->
s
->
table_name
;
DBUG_PRINT
(
"info"
,
(
"use_table: %.*s"
,
name
.
length
,
name
.
str
));
injector
::
transaction
::
table
tbl
(
table
,
true
);
trans
.
use_table
(
::
server_id
,
tbl
);
DBUG_PRINT
(
"info"
,
(
"Found new data event, initializing transaction"
));
inj
->
new_trans
(
thd
,
&
trans
);
}
DBUG_PRINT
(
"info"
,
(
"use_table: %.*s"
,
name
.
length
,
name
.
str
));
injector
::
transaction
::
table
tbl
(
table
,
true
);
int
ret
=
trans
.
use_table
(
::
server_id
,
tbl
);
DBUG_ASSERT
(
ret
==
0
);
}
}
gci
=
pOp
->
getGCI
();
if
(
apply_status_share
)
{
TABLE
*
table
=
apply_status_share
->
table
;
const
LEX_STRING
&
name
=
table
->
s
->
table_name
;
DBUG_PRINT
(
"info"
,
(
"use_table: %.*s"
,
name
.
length
,
name
.
str
));
injector
::
transaction
::
table
tbl
(
table
,
true
);
trans
.
use_table
(
::
server_id
,
tbl
);
MY_BITMAP
b
;
uint32
bitbuf
;
DBUG_ASSERT
(
table
->
s
->
fields
<=
sizeof
(
bitbuf
)
*
8
);
bitmap_init
(
&
b
,
&
bitbuf
,
table
->
s
->
fields
,
false
);
bitmap_set_all
(
&
b
);
table
->
field
[
0
]
->
store
((
longlong
)
::
server_id
);
table
->
field
[
1
]
->
store
((
longlong
)
gci
);
trans
.
write_row
(
::
server_id
,
injector
::
transaction
::
table
(
table
,
true
),
&
b
,
table
->
s
->
fields
,
table
->
record
[
0
]);
}
else
if
(
trans
.
good
())
{
sql_print_error
(
"NDB: Could not get apply status share"
);
if
(
apply_status_share
)
{
TABLE
*
table
=
apply_status_share
->
table
;
const
LEX_STRING
&
name
=
table
->
s
->
table_name
;
DBUG_PRINT
(
"info"
,
(
"use_table: %.*s"
,
name
.
length
,
name
.
str
));
injector
::
transaction
::
table
tbl
(
table
,
true
);
int
ret
=
trans
.
use_table
(
::
server_id
,
tbl
);
DBUG_ASSERT
(
ret
==
0
);
MY_BITMAP
b
;
uint32
bitbuf
;
DBUG_ASSERT
(
table
->
s
->
fields
<=
sizeof
(
bitbuf
)
*
8
);
bitmap_init
(
&
b
,
&
bitbuf
,
table
->
s
->
fields
,
false
);
bitmap_set_all
(
&
b
);
table
->
field
[
0
]
->
store
((
longlong
)
::
server_id
);
table
->
field
[
1
]
->
store
((
longlong
)
gci
);
trans
.
write_row
(
::
server_id
,
injector
::
transaction
::
table
(
table
,
true
),
&
b
,
table
->
s
->
fields
,
table
->
record
[
0
]);
}
else
{
sql_print_error
(
"NDB: Could not get apply status share"
);
}
}
#ifdef RUN_NDB_BINLOG_TIMER
write_timer
.
start
();
...
...
@@ -3142,11 +3174,28 @@ pthread_handler_t ndb_binlog_thread_func(void *arg)
{
NDB_SHARE
*
share
=
(
NDB_SHARE
*
)
pOp
->
getCustomData
();
DBUG_PRINT
(
"info"
,
(
"EVENT TYPE:%d GCI:%lld last applied: %lld "
"share: 0x%lx"
,
pOp
->
getEventType
(),
gci
,
ndb_latest_applied_binlog_epoch
,
share
));
(
"EVENT TYPE: %d GCI: %lld last applied: %lld "
"share: 0x%lx (%s.%s)"
,
pOp
->
getEventType
(),
gci
,
ndb_latest_applied_binlog_epoch
,
share
,
share
?
share
->
db
:
"share == NULL"
,
share
?
share
->
table_name
:
""
));
DBUG_ASSERT
(
share
!=
0
);
}
// assert that there is consistancy between gci op list
// and event list
{
Uint32
iter
=
0
;
const
NdbEventOperation
*
gci_op
;
Uint32
event_types
;
while
((
gci_op
=
ndb
->
getGCIEventOperations
(
&
iter
,
&
event_types
))
!=
NULL
)
{
if
(
gci_op
==
pOp
)
break
;
}
DBUG_ASSERT
(
gci_op
==
pOp
);
DBUG_ASSERT
((
event_types
&
pOp
->
getEventType
())
!=
0
);
}
#endif
if
((
unsigned
)
pOp
->
getEventType
()
<
(
unsigned
)
NDBEVENT
::
TE_FIRST_NON_DATA_EVENT
)
...
...
@@ -3154,8 +3203,9 @@ pthread_handler_t ndb_binlog_thread_func(void *arg)
else
{
// set injector_ndb database/schema from table internal name
int
ret
=
ndb
->
setDatabaseAndSchemaName
(
pOp
->
getEvent
()
->
getTable
());
assert
(
ret
==
0
);
int
ret
=
ndb
->
setDatabaseAndSchemaName
(
pOp
->
getEvent
()
->
getTable
());
DBUG_ASSERT
(
ret
==
0
);
ndb_binlog_thread_handle_non_data_event
(
ndb
,
pOp
,
row
);
// reset to catch errors
ndb
->
setDatabaseName
(
""
);
...
...
@@ -3172,13 +3222,13 @@ pthread_handler_t ndb_binlog_thread_func(void *arg)
write_timer
.
stop
();
#endif
if
(
row
.
n_inserts
||
row
.
n_updates
||
row
.
n_deletes
||
row
.
n_schemaops
)
if
(
trans
.
good
())
{
DBUG_ASSERT
(
row
.
n_inserts
||
row
.
n_updates
||
row
.
n_deletes
);
injector
::
transaction
::
binlog_pos
start
=
trans
.
start_pos
();
if
(
int
r
=
trans
.
commit
())
{
sql_print_error
(
"NDB binlog:"
sql_print_error
(
"NDB binlog:
"
"Error during COMMIT of GCI. Error: %d"
,
r
);
/* TODO: Further handling? */
...
...
@@ -3187,13 +3237,11 @@ pthread_handler_t ndb_binlog_thread_func(void *arg)
row
.
master_log_file
=
start
.
file_name
();
row
.
master_log_pos
=
start
.
file_pos
();
DBUG_PRINT
(
"info"
,
(
"COMMIT gci %lld"
,
gci
));
DBUG_PRINT
(
"info"
,
(
"COMMIT gci: %lld"
,
gci
));
if
(
ndb_update_binlog_index
)
ndb_add_binlog_index
(
thd
,
&
row
);
ndb_latest_applied_binlog_epoch
=
gci
;
}
else
trans
.
commit
();
ndb_latest_handled_binlog_epoch
=
gci
;
#ifdef RUN_NDB_BINLOG_TIMER
gci_timer
.
stop
();
...
...
sql/rpl_injector.cc
View file @
b9dcd3b1
...
...
@@ -43,6 +43,9 @@ injector::transaction::transaction(MYSQL_LOG *log, THD *thd)
injector
::
transaction
::~
transaction
()
{
if
(
!
good
())
return
;
/* Needed since my_free expects a 'char*' (instead of 'void*'). */
char
*
const
the_memory
=
const_cast
<
char
*>
(
m_start_pos
.
m_file_name
);
...
...
sql/rpl_injector.h
View file @
b9dcd3b1
...
...
@@ -235,6 +235,11 @@ public:
m_thd
=
o
.
m_thd
;
o
.
m_thd
=
tmp
;
}
{
enum_state
const
tmp
=
m_state
;
m_state
=
o
.
m_state
;
o
.
m_state
=
tmp
;
}
}
enum
enum_state
...
...
storage/ndb/src/kernel/blocks/dbdict/Dbdict.cpp
View file @
b9dcd3b1
...
...
@@ -348,7 +348,7 @@ void Dbdict::packTableIntoPages(Signal* signal)
memset
(
&
pagePtr
.
p
->
word
[
0
],
0
,
4
*
ZPAGE_HEADER_SIZE
);
LinearWriter
w
(
&
pagePtr
.
p
->
word
[
ZPAGE_HEADER_SIZE
],
8
*
ZSIZE_OF_PAGES_IN_WORDS
);
ZMAX_PAGES_OF_TABLE_DEFINITION
*
ZSIZE_OF_PAGES_IN_WORDS
);
w
.
first
();
switch
((
DictTabInfo
::
TableType
)
type
)
{
case
DictTabInfo
:
:
SystemTable
:
...
...
storage/ndb/src/kernel/blocks/suma/Suma.cpp
View file @
b9dcd3b1
...
...
@@ -2565,6 +2565,9 @@ Suma::reportAllSubscribers(Signal *signal,
return
;
}
#ifdef VM_TRACE
ndbout_c
(
"reportAllSubscribers"
);
#endif
SubTableData
*
data
=
(
SubTableData
*
)
signal
->
getDataPtrSend
();
data
->
gci
=
m_last_complete_gci
+
1
;
data
->
tableId
=
subPtr
.
p
->
m_tableId
;
...
...
@@ -2591,6 +2594,12 @@ Suma::reportAllSubscribers(Signal *signal,
data
->
senderData
=
subbPtr
.
p
->
m_senderData
;
sendSignal
(
subbPtr
.
p
->
m_senderRef
,
GSN_SUB_TABLE_DATA
,
signal
,
SubTableData
::
SignalLength
,
JBB
);
#ifdef VM_TRACE
ndbout_c
(
"sent %s(%d) to node %d"
,
table_event
==
NdbDictionary
::
Event
::
_TE_SUBSCRIBE
?
"SUBSCRIBE"
:
"UNSUBSCRIBE"
,
(
int
)
table_event
,
refToNode
(
subbPtr
.
p
->
m_senderRef
));
#endif
}
}
}
...
...
storage/ndb/src/ndbapi/NdbEventOperationImpl.cpp
View file @
b9dcd3b1
...
...
@@ -1173,15 +1173,17 @@ NdbEventBuffer::nextEvent()
NdbEventOperationImpl
*
NdbEventBuffer
::
getGCIEventOperations
(
Uint32
*
iter
,
Uint32
*
event_types
)
{
DBUG_ENTER
(
"NdbEventBuffer::getGCIEventOperations"
);
EventBufData_list
::
Gci_ops
*
gci_ops
=
m_available_data
.
first_gci_ops
();
if
(
*
iter
<
gci_ops
->
m_gci_op_count
)
{
EventBufData_list
::
Gci_op
g
=
gci_ops
->
m_gci_op_list
[(
*
iter
)
++
];
if
(
event_types
!=
NULL
)
*
event_types
=
g
.
event_types
;
return
g
.
op
;
DBUG_PRINT
(
"info"
,
(
"gci: %d"
,
(
unsigned
)
gci_ops
->
m_gci
));
DBUG_RETURN
(
g
.
op
);
}
return
NULL
;
DBUG_RETURN
(
NULL
)
;
}
void
...
...
@@ -1647,11 +1649,19 @@ NdbEventBuffer::insertDataL(NdbEventOperationImpl *op,
else
{
// event with same op, PK found, merge into old buffer
Uint32
old_op
=
data
->
sdata
->
operation
;
if
(
unlikely
(
merge_data
(
sdata
,
ptr
,
data
)))
{
op
->
m_has_error
=
3
;
DBUG_RETURN_EVENT
(
-
1
);
}
Uint32
new_op
=
data
->
sdata
->
operation
;
// make Gci_ops reflect the merge by delete old and add new
EventBufData_list
::
Gci_op
g
=
{
op
,
(
1
<<
old_op
)
};
// bucket->m_data.del_gci_op(g); // XXX whats wrong? fix later
g
.
event_types
=
(
1
<<
new_op
);
bucket
->
m_data
.
add_gci_op
(
g
);
}
DBUG_RETURN_EVENT
(
0
);
}
...
...
@@ -2184,7 +2194,7 @@ void EventBufData_list::append_list(EventBufData_list *list, Uint64 gci)
}
void
EventBufData_list
::
add_gci_op
(
Gci_op
g
)
EventBufData_list
::
add_gci_op
(
Gci_op
g
,
bool
del
)
{
assert
(
g
.
op
!=
NULL
);
Uint32
i
;
...
...
@@ -2193,7 +2203,10 @@ EventBufData_list::add_gci_op(Gci_op g)
break
;
}
if
(
i
<
m_gci_op_count
)
{
m_gci_op_list
[
i
].
event_types
|=
g
.
event_types
;
if
(
!
del
)
m_gci_op_list
[
i
].
event_types
|=
g
.
event_types
;
else
m_gci_op_list
[
i
].
event_types
&=
~
g
.
event_types
;
}
else
{
if
(
m_gci_op_count
==
m_gci_op_alloc
)
{
Uint32
n
=
1
+
2
*
m_gci_op_alloc
;
...
...
@@ -2207,6 +2220,7 @@ EventBufData_list::add_gci_op(Gci_op g)
m_gci_op_alloc
=
n
;
}
assert
(
m_gci_op_count
<
m_gci_op_alloc
);
assert
(
!
del
);
m_gci_op_list
[
m_gci_op_count
++
]
=
g
;
}
}
...
...
storage/ndb/src/ndbapi/NdbEventOperationImpl.hpp
View file @
b9dcd3b1
...
...
@@ -129,9 +129,11 @@ public:
};
Gci_ops
*
first_gci_ops
();
Gci_ops
*
next_gci_ops
();
private:
// case 1 above; add Gci_op to single list
void
add_gci_op
(
Gci_op
g
);
void
add_gci_op
(
Gci_op
g
,
bool
del
=
false
);
// delete bit from existing flags
void
del_gci_op
(
Gci_op
g
)
{
add_gci_op
(
g
,
true
);
}
private:
// case 2 above; move single list or multi list from
// one list to another
void
move_gci_ops
(
EventBufData_list
*
list
,
Uint64
gci
);
...
...
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