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
c172cab8
Commit
c172cab8
authored
Jun 03, 2003
by
guilhem@mysql.com
Browse files
Options
Browse Files
Download
Plain Diff
Merge gbichot@213.136.52.20:/home/bk/mysql-4.0
into mysql.com:/home/mysql_src/mysql-4.0
parents
5a6d4e7e
4a80a6c7
Changes
7
Show whitespace changes
Inline
Side-by-side
Showing
7 changed files
with
76 additions
and
16 deletions
+76
-16
mysql-test/r/rpl_loaddata.result
mysql-test/r/rpl_loaddata.result
+6
-0
mysql-test/t/rpl_loaddata.test
mysql-test/t/rpl_loaddata.test
+17
-0
sql/log_event.cc
sql/log_event.cc
+31
-6
sql/slave.cc
sql/slave.cc
+1
-1
sql/sql_repl.cc
sql/sql_repl.cc
+1
-7
sql/sql_yacc.yy
sql/sql_yacc.yy
+14
-0
sql/unireg.h
sql/unireg.h
+6
-2
No files found.
mysql-test/r/rpl_loaddata.result
View file @
c172cab8
...
@@ -22,3 +22,9 @@ day id category name
...
@@ -22,3 +22,9 @@ day id category name
drop table t1;
drop table t1;
drop table t2;
drop table t2;
drop table t3;
drop table t3;
create table t1(a int, b int, unique(b));
insert into t1 values(1,10);
load data infile '../../std_data/rpl_loaddata.dat' into table t1;
show status like 'slave_running';
Variable_name Value
Slave_running OFF
mysql-test/t/rpl_loaddata.test
View file @
c172cab8
...
@@ -4,6 +4,9 @@
...
@@ -4,6 +4,9 @@
#
#
# check replication of load data for temporary tables with additional parameters
# check replication of load data for temporary tables with additional parameters
#
#
# check if duplicate entries trigger an error (they should unless IGNORE or
# REPLACE was used on the master) (bug 571).
source
include
/
master
-
slave
.
inc
;
source
include
/
master
-
slave
.
inc
;
create
table
t1
(
a
int
not
null
auto_increment
,
b
int
,
primary
key
(
a
)
);
create
table
t1
(
a
int
not
null
auto_increment
,
b
int
,
primary
key
(
a
)
);
...
@@ -27,7 +30,21 @@ connection master;
...
@@ -27,7 +30,21 @@ connection master;
drop
table
t1
;
drop
table
t1
;
drop
table
t2
;
drop
table
t2
;
drop
table
t3
;
drop
table
t3
;
create
table
t1
(
a
int
,
b
int
,
unique
(
b
));
save_master_pos
;
save_master_pos
;
connection
slave
;
connection
slave
;
sync_with_master
;
sync_with_master
;
insert
into
t1
values
(
1
,
10
);
connection
master
;
load
data
infile
'../../std_data/rpl_loaddata.dat'
into
table
t1
;
save_master_pos
;
connection
slave
;
# don't sync_with_master because the slave SQL thread should be stopped because
# of the error so MASTER_POS_WAIT() will not return; just sleep and hope the
# slave SQL thread will have had time to stop.
sleep
1
;
show
status
like
'slave_running'
;
sql/log_event.cc
View file @
c172cab8
...
@@ -1886,9 +1886,27 @@ int Load_log_event::exec_event(NET* net, struct st_relay_log_info* rli,
...
@@ -1886,9 +1886,27 @@ int Load_log_event::exec_event(NET* net, struct st_relay_log_info* rli,
else
else
{
{
char
llbuff
[
22
];
char
llbuff
[
22
];
enum
enum_duplicates
handle_dup
=
DUP_IGNORE
;
enum
enum_duplicates
handle_dup
;
if
(
sql_ex
.
opt_flags
&
REPLACE_FLAG
)
if
(
sql_ex
.
opt_flags
&
REPLACE_FLAG
)
handle_dup
=
DUP_REPLACE
;
handle_dup
=
DUP_REPLACE
;
else
if
(
sql_ex
.
opt_flags
&
IGNORE_FLAG
)
handle_dup
=
DUP_IGNORE
;
else
/*
Note that when replication is running fine, if it was DUP_ERROR on the
master then we could choose DUP_IGNORE here, because if DUP_ERROR
suceeded on master, and data is identical on the master and slave,
then there should be no uniqueness errors on slave, so DUP_IGNORE is
the same as DUP_ERROR. But in the unlikely case of uniqueness errors
(because the data on the master and slave happen to be different (user
error or bug), we want LOAD DATA to print an error message on the
slave to discover the problem.
If reading from net (a 3.23 master), mysql_load() will change this
to DUP_IGNORE.
*/
handle_dup
=
DUP_ERROR
;
sql_exchange
ex
((
char
*
)
fname
,
sql_ex
.
opt_flags
&
DUMPFILE_FLAG
);
sql_exchange
ex
((
char
*
)
fname
,
sql_ex
.
opt_flags
&
DUMPFILE_FLAG
);
String
field_term
(
sql_ex
.
field_term
,
sql_ex
.
field_term_len
);
String
field_term
(
sql_ex
.
field_term
,
sql_ex
.
field_term_len
);
String
enclosed
(
sql_ex
.
enclosed
,
sql_ex
.
enclosed_len
);
String
enclosed
(
sql_ex
.
enclosed
,
sql_ex
.
enclosed_len
);
...
@@ -1949,12 +1967,19 @@ int Load_log_event::exec_event(NET* net, struct st_relay_log_info* rli,
...
@@ -1949,12 +1967,19 @@ int Load_log_event::exec_event(NET* net, struct st_relay_log_info* rli,
close_thread_tables
(
thd
);
close_thread_tables
(
thd
);
if
(
thd
->
query_error
)
if
(
thd
->
query_error
)
{
{
int
sql_error
=
thd
->
net
.
last_errno
;
/* this err/sql_errno code is copy-paste from send_error() */
if
(
!
sql_error
)
const
char
*
err
;
sql_error
=
ER_UNKNOWN_ERROR
;
int
sql_errno
;
slave_print_error
(
rli
,
sql_error
,
if
((
err
=
thd
->
net
.
last_error
)[
0
])
sql_errno
=
thd
->
net
.
last_errno
;
else
{
sql_errno
=
ER_UNKNOWN_ERROR
;
err
=
ER
(
sql_errno
);
}
slave_print_error
(
rli
,
sql_errno
,
"Error '%s' running load data infile"
,
"Error '%s' running load data infile"
,
ER_SAFE
(
sql_error
)
);
err
);
free_root
(
&
thd
->
mem_root
,
0
);
free_root
(
&
thd
->
mem_root
,
0
);
return
1
;
return
1
;
}
}
...
...
sql/slave.cc
View file @
c172cab8
...
@@ -269,7 +269,7 @@ int init_relay_log_pos(RELAY_LOG_INFO* rli,const char* log,
...
@@ -269,7 +269,7 @@ int init_relay_log_pos(RELAY_LOG_INFO* rli,const char* log,
goto
err
;
goto
err
;
rli
->
cur_log
=
&
rli
->
cache_buf
;
rli
->
cur_log
=
&
rli
->
cache_buf
;
}
}
if
(
pos
>
BIN_LOG_HEADER_SIZE
)
if
(
pos
>
=
BIN_LOG_HEADER_SIZE
)
my_b_seek
(
rli
->
cur_log
,(
off_t
)
pos
);
my_b_seek
(
rli
->
cur_log
,(
off_t
)
pos
);
err:
err:
...
...
sql/sql_repl.cc
View file @
c172cab8
...
@@ -961,7 +961,7 @@ int show_binlog_events(THD* thd)
...
@@ -961,7 +961,7 @@ int show_binlog_events(THD* thd)
{
{
LEX_MASTER_INFO
*
lex_mi
=
&
thd
->
lex
.
mi
;
LEX_MASTER_INFO
*
lex_mi
=
&
thd
->
lex
.
mi
;
ha_rows
event_count
,
limit_start
,
limit_end
;
ha_rows
event_count
,
limit_start
,
limit_end
;
my_off_t
pos
=
lex_mi
->
pos
;
my_off_t
pos
=
max
(
BIN_LOG_HEADER_SIZE
,
lex_mi
->
pos
);
// user-friendly
char
search_file_name
[
FN_REFLEN
],
*
name
;
char
search_file_name
[
FN_REFLEN
],
*
name
;
const
char
*
log_file_name
=
lex_mi
->
log_file_name
;
const
char
*
log_file_name
=
lex_mi
->
log_file_name
;
pthread_mutex_t
*
log_lock
=
mysql_bin_log
.
get_log_lock
();
pthread_mutex_t
*
log_lock
=
mysql_bin_log
.
get_log_lock
();
...
@@ -989,12 +989,6 @@ int show_binlog_events(THD* thd)
...
@@ -989,12 +989,6 @@ int show_binlog_events(THD* thd)
if
((
file
=
open_binlog
(
&
log
,
linfo
.
log_file_name
,
&
errmsg
))
<
0
)
if
((
file
=
open_binlog
(
&
log
,
linfo
.
log_file_name
,
&
errmsg
))
<
0
)
goto
err
;
goto
err
;
if
(
pos
<
4
)
{
errmsg
=
"Invalid log position"
;
goto
err
;
}
pthread_mutex_lock
(
log_lock
);
pthread_mutex_lock
(
log_lock
);
my_b_seek
(
&
log
,
pos
);
my_b_seek
(
&
log
,
pos
);
...
...
sql/sql_yacc.yy
View file @
c172cab8
...
@@ -706,6 +706,18 @@ master_def:
...
@@ -706,6 +706,18 @@ master_def:
MASTER_LOG_POS_SYM EQ ulonglong_num
MASTER_LOG_POS_SYM EQ ulonglong_num
{
{
Lex->mi.pos = $3;
Lex->mi.pos = $3;
/*
If the user specified a value < BIN_LOG_HEADER_SIZE, adjust it
instead of causing subsequent errors.
We need to do it in this file, because only there we know that
MASTER_LOG_POS has been explicitely specified. On the contrary
in change_master() (sql_repl.cc) we cannot distinguish between 0
(MASTER_LOG_POS explicitely specified as 0) and 0 (unspecified),
whereas we want to distinguish (specified 0 means "read the binlog
from 0" (4 in fact), unspecified means "don't change the position
(keep the preceding value)").
*/
Lex->mi.pos = max(BIN_LOG_HEADER_SIZE, Lex->mi.pos);
}
}
|
|
MASTER_CONNECT_RETRY_SYM EQ ULONG_NUM
MASTER_CONNECT_RETRY_SYM EQ ULONG_NUM
...
@@ -721,6 +733,8 @@ master_def:
...
@@ -721,6 +733,8 @@ master_def:
RELAY_LOG_POS_SYM EQ ULONG_NUM
RELAY_LOG_POS_SYM EQ ULONG_NUM
{
{
Lex->mi.relay_log_pos = $3;
Lex->mi.relay_log_pos = $3;
/* Adjust if < BIN_LOG_HEADER_SIZE (same comment as Lex->mi.pos) */
Lex->mi.relay_log_pos = max(BIN_LOG_HEADER_SIZE, Lex->mi.relay_log_pos);
};
};
...
...
sql/unireg.h
View file @
c172cab8
...
@@ -130,7 +130,11 @@ bfill((A)->null_flags,(A)->null_bytes,255);\
...
@@ -130,7 +130,11 @@ bfill((A)->null_flags,(A)->null_bytes,255);\
*/
*/
#define MIN_TURBOBM_PATTERN_LEN 3
#define MIN_TURBOBM_PATTERN_LEN 3
/* Defines for binary logging */
/*
Defines for binary logging.
Do not decrease the value of BIN_LOG_HEADER_SIZE.
Do not even increase it before checking code.
*/
#define BIN_LOG_HEADER_SIZE 4
#define BIN_LOG_HEADER_SIZE 4
...
...
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