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
9310ad5f
Commit
9310ad5f
authored
Jul 10, 2007
by
tnurnberg@sin.intern.azundris.com
Browse files
Options
Browse Files
Download
Plain Diff
Merge mysql.com:/home/tnurnberg/22540/50-22540
into mysql.com:/home/tnurnberg/22540/51-22540
parents
5230ed7a
3dfc83f1
Changes
3
Expand all
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
430 additions
and
586 deletions
+430
-586
mysql-test/extra/binlog_tests/binlog.test
mysql-test/extra/binlog_tests/binlog.test
+0
-61
mysql-test/suite/binlog/r/binlog_stm_binlog.result
mysql-test/suite/binlog/r/binlog_stm_binlog.result
+413
-510
sql/log.cc
sql/log.cc
+17
-15
No files found.
mysql-test/extra/binlog_tests/binlog.test
View file @
9310ad5f
...
@@ -80,72 +80,11 @@ drop table t1;
...
@@ -80,72 +80,11 @@ drop table t1;
--
replace_regex
/
\
/
\
*
xid
=.*
\
*
\
//\/* XID *\// /table_id: [0-9]+/table_id: #/ /Server ver: [^,]*,/Server version,/
--
replace_regex
/
\
/
\
*
xid
=.*
\
*
\
//\/* XID *\// /table_id: [0-9]+/table_id: #/ /Server ver: [^,]*,/Server version,/
show
binlog
events
from
0
;
show
binlog
events
from
0
;
set
autocommit
=
1
;
reset
master
;
create
table
t1
(
n
int
)
engine
=
innodb
;
insert
into
t1
values
(
1
);
insert
into
t1
values
(
2
);
insert
into
t1
values
(
3
);
commit
;
drop
table
t1
;
--
replace_regex
/
\
/
\
*
xid
=.*
\
*
\
//\/* XID *\// /table_id: [0-9]+/table_id: #/ /Server ver: [^,]*,/Server version,/
show
binlog
events
from
0
;
reset
master
;
create
table
t1
(
n
int
)
engine
=
myisam
;
begin
;
insert
into
t1
values
(
4
);
insert
into
t1
values
(
5
);
insert
into
t1
values
(
6
);
commit
;
drop
table
t1
;
--
replace_regex
/
\
/
\
*
xid
=.*
\
*
\
//\/* XID *\// /table_id: [0-9]+/table_id: #/ /Server ver: [^,]*,/Server version,/
show
binlog
events
from
0
;
# now show this also works for SHOW MASTER STATUS
# as this is what "mysqldump --master-data=1" uses.
set
autocommit
=
1
;
reset
master
;
create
table
t1
(
n
int
)
engine
=
innodb
;
show
master
status
;
insert
into
t1
values
(
1
);
show
master
status
;
insert
into
t1
values
(
2
);
insert
into
t1
values
(
3
);
show
master
status
;
commit
;
show
master
status
;
drop
table
t1
;
--
replace_regex
/
\
/
\
*
xid
=.*
\
*
\
//\/* XID *\// /table_id: [0-9]+/table_id: #/ /Server ver: [^,]*,/Server version,/
show
binlog
events
from
0
;
set
autocommit
=
0
;
reset
master
;
create
table
t1
(
n
int
)
engine
=
myisam
;
show
master
status
;
insert
into
t1
values
(
4
);
show
master
status
;
insert
into
t1
values
(
5
);
insert
into
t1
values
(
6
);
show
master
status
;
commit
;
show
master
status
;
drop
table
t1
;
--
replace_regex
/
\
/
\
*
xid
=.*
\
*
\
//\/* XID *\// /table_id: [0-9]+/table_id: #/ /Server ver: [^,]*,/Server version,/
show
binlog
events
from
0
;
set
session
autocommit
=
@
ac
;
# now show that nothing breaks if we need to read from the cache more
# now show that nothing breaks if we need to read from the cache more
# than once, resulting in split event-headers
# than once, resulting in split event-headers
set
@
bcs
=
@@
binlog_cache_size
;
set
@
bcs
=
@@
binlog_cache_size
;
set
@
ac
=
@@
autocommit
;
set
global
binlog_cache_size
=
4096
;
set
global
binlog_cache_size
=
4096
;
set
autocommit
=
0
;
reset
master
;
reset
master
;
create
table
t1
(
a
int
)
engine
=
innodb
;
create
table
t1
(
a
int
)
engine
=
innodb
;
...
...
mysql-test/suite/binlog/r/binlog_stm_binlog.result
View file @
9310ad5f
This diff is collapsed.
Click to expand it.
sql/log.cc
View file @
9310ad5f
...
@@ -3945,7 +3945,7 @@ int MYSQL_BIN_LOG::write_cache(IO_CACHE *cache, bool lock_log, bool sync_log)
...
@@ -3945,7 +3945,7 @@ int MYSQL_BIN_LOG::write_cache(IO_CACHE *cache, bool lock_log, bool sync_log)
if
(
reinit_io_cache
(
cache
,
READ_CACHE
,
0
,
0
,
0
))
if
(
reinit_io_cache
(
cache
,
READ_CACHE
,
0
,
0
,
0
))
return
ER_ERROR_ON_WRITE
;
return
ER_ERROR_ON_WRITE
;
uint
bytes
=
my_b_bytes_in_cache
(
cache
),
group
,
carry
,
hdr_offs
;
uint
length
=
my_b_bytes_in_cache
(
cache
),
group
,
carry
,
hdr_offs
;
long
val
;
long
val
;
uchar
header
[
LOG_EVENT_HEADER_LEN
];
uchar
header
[
LOG_EVENT_HEADER_LEN
];
...
@@ -4002,7 +4002,7 @@ int MYSQL_BIN_LOG::write_cache(IO_CACHE *cache, bool lock_log, bool sync_log)
...
@@ -4002,7 +4002,7 @@ int MYSQL_BIN_LOG::write_cache(IO_CACHE *cache, bool lock_log, bool sync_log)
/* if there is anything to write, process it. */
/* if there is anything to write, process it. */
if
(
likely
(
bytes
>
0
))
if
(
likely
(
length
>
0
))
{
{
/*
/*
process all event-headers in this (partial) cache.
process all event-headers in this (partial) cache.
...
@@ -4011,18 +4011,18 @@ int MYSQL_BIN_LOG::write_cache(IO_CACHE *cache, bool lock_log, bool sync_log)
...
@@ -4011,18 +4011,18 @@ int MYSQL_BIN_LOG::write_cache(IO_CACHE *cache, bool lock_log, bool sync_log)
very next iteration, just "eventually").
very next iteration, just "eventually").
*/
*/
while
(
hdr_offs
<
bytes
)
while
(
hdr_offs
<
length
)
{
{
/*
/*
partial header only? save what we can get, process once
partial header only? save what we can get, process once
we get the rest.
we get the rest.
*/
*/
if
(
hdr_offs
+
LOG_EVENT_HEADER_LEN
>
bytes
)
if
(
hdr_offs
+
LOG_EVENT_HEADER_LEN
>
length
)
{
{
carry
=
bytes
-
hdr_offs
;
carry
=
length
-
hdr_offs
;
memcpy
(
header
,
(
char
*
)
cache
->
read_pos
+
hdr_offs
,
carry
);
memcpy
(
header
,
(
char
*
)
cache
->
read_pos
+
hdr_offs
,
carry
);
bytes
=
hdr_offs
;
length
=
hdr_offs
;
}
}
else
else
{
{
...
@@ -4042,21 +4042,23 @@ int MYSQL_BIN_LOG::write_cache(IO_CACHE *cache, bool lock_log, bool sync_log)
...
@@ -4042,21 +4042,23 @@ int MYSQL_BIN_LOG::write_cache(IO_CACHE *cache, bool lock_log, bool sync_log)
}
}
/*
/*
Adjust hdr_offs. Note that this doesn't mean it will necessarily
Adjust hdr_offs. Note that it may still point beyond the segment
be valid in the next iteration; if the current event is very long,
read in the next iteration; if the current event is very long,
it may take a couple of read-iterations (and subsequent fixings
it may take a couple of read-iterations (and subsequent adjustments
of hdr_offs) for it to become valid again.
of hdr_offs) for it to point into the then-current segment.
if we had a split header, hdr_offs was already fixed above.
If we have a split header (!carry), hdr_offs will be set at the
beginning of the next iteration, overwriting the value we set here:
*/
*/
if
(
carry
==
0
)
hdr_offs
-=
length
;
hdr_offs
-=
bytes
;
}
}
/* Write data to the binary log file */
/* Write data to the binary log file */
if
(
my_b_write
(
&
log_file
,
cache
->
read_pos
,
bytes
))
if
(
my_b_write
(
&
log_file
,
cache
->
read_pos
,
length
))
return
ER_ERROR_ON_WRITE
;
return
ER_ERROR_ON_WRITE
;
cache
->
read_pos
=
cache
->
read_end
;
// Mark buffer used up
cache
->
read_pos
=
cache
->
read_end
;
// Mark buffer used up
}
while
((
bytes
=
my_b_fill
(
cache
)));
}
while
((
length
=
my_b_fill
(
cache
)));
DBUG_ASSERT
(
carry
==
0
);
if
(
sync_log
)
if
(
sync_log
)
flush_and_sync
();
flush_and_sync
();
...
...
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