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
32f1e3b0
Commit
32f1e3b0
authored
Mar 24, 2005
by
gbichot@quadita2.mysql.com
Browse files
Options
Browse Files
Download
Plain Diff
Merge gbichot@bk-internal.mysql.com:/home/bk/mysql-5.0
into quadita2.mysql.com:/nfstmp1/guilhem/mysql-5.0-4ita
parents
a8c1316c
5acca04c
Changes
8
Hide whitespace changes
Inline
Side-by-side
Showing
8 changed files
with
63 additions
and
14 deletions
+63
-14
libmysql/Makefile.shared
libmysql/Makefile.shared
+2
-1
mysql-test/r/rpl_deadlock.result
mysql-test/r/rpl_deadlock.result
+6
-0
mysql-test/t/rpl_deadlock.test
mysql-test/t/rpl_deadlock.test
+4
-0
sql/mysqld.cc
sql/mysqld.cc
+13
-3
sql/slave.cc
sql/slave.cc
+16
-8
sql/slave.h
sql/slave.h
+8
-1
sql/sql_show.cc
sql/sql_show.cc
+13
-0
sql/structs.h
sql/structs.h
+1
-1
No files found.
libmysql/Makefile.shared
View file @
32f1e3b0
...
@@ -96,7 +96,8 @@ clean-local:
...
@@ -96,7 +96,8 @@ clean-local:
`
echo
$(sql_cmn_objects)
|
sed
"s;
\.
lo;.c;g"
`
\
`
echo
$(sql_cmn_objects)
|
sed
"s;
\.
lo;.c;g"
`
\
$(CHARSET_SRCS)
$(CHARSET_OBJS)
\
$(CHARSET_SRCS)
$(CHARSET_OBJS)
\
$(mystringsextra)
$(mysysheaders)
$(vioheaders)
\
$(mystringsextra)
$(mysysheaders)
$(vioheaders)
\
../linked_client_sources net.c
../linked_libmysql_sources ../linked_libmysql_r_sources
\
net.c
conf_to_src_SOURCES
=
conf_to_src.c
conf_to_src_SOURCES
=
conf_to_src.c
conf_to_src_LDADD
=
conf_to_src_LDADD
=
...
...
mysql-test/r/rpl_deadlock.result
View file @
32f1e3b0
...
@@ -8,6 +8,9 @@ create table t1 (a int not null, key(a)) engine=innodb;
...
@@ -8,6 +8,9 @@ create table t1 (a int not null, key(a)) engine=innodb;
create table t2 (a int not null, key(a)) engine=innodb;
create table t2 (a int not null, key(a)) engine=innodb;
create table t3 (a int) engine=innodb;
create table t3 (a int) engine=innodb;
create table t4 (a int) engine=innodb;
create table t4 (a int) engine=innodb;
show variables like 'slave_transaction_retries';
Variable_name Value
slave_transaction_retries 0
show create table t1;
show create table t1;
Table Create Table
Table Create Table
t1 CREATE TABLE `t1` (
t1 CREATE TABLE `t1` (
...
@@ -20,6 +23,9 @@ t2 CREATE TABLE `t2` (
...
@@ -20,6 +23,9 @@ t2 CREATE TABLE `t2` (
`a` int(11) NOT NULL,
`a` int(11) NOT NULL,
KEY `a` (`a`)
KEY `a` (`a`)
) ENGINE=InnoDB DEFAULT CHARSET=latin1
) ENGINE=InnoDB DEFAULT CHARSET=latin1
show variables like 'slave_transaction_retries';
Variable_name Value
slave_transaction_retries 2
stop slave;
stop slave;
begin;
begin;
insert into t3 select * from t2 for update;
insert into t3 select * from t2 for update;
...
...
mysql-test/t/rpl_deadlock.test
View file @
32f1e3b0
...
@@ -7,6 +7,8 @@
...
@@ -7,6 +7,8 @@
# (Guilhem) have seen the test manage to provoke lock wait timeout
# (Guilhem) have seen the test manage to provoke lock wait timeout
# error but not deadlock error; that is ok as code deals with the two
# error but not deadlock error; that is ok as code deals with the two
# errors in exactly the same way.
# errors in exactly the same way.
# We don't 'show status like 'slave_retried_transactions'' because this
# is not repeatable (depends on sleeps).
source
include
/
have_innodb
.
inc
;
source
include
/
have_innodb
.
inc
;
source
include
/
master
-
slave
.
inc
;
source
include
/
master
-
slave
.
inc
;
...
@@ -16,10 +18,12 @@ create table t1 (a int not null, key(a)) engine=innodb;
...
@@ -16,10 +18,12 @@ create table t1 (a int not null, key(a)) engine=innodb;
create
table
t2
(
a
int
not
null
,
key
(
a
))
engine
=
innodb
;
create
table
t2
(
a
int
not
null
,
key
(
a
))
engine
=
innodb
;
create
table
t3
(
a
int
)
engine
=
innodb
;
create
table
t3
(
a
int
)
engine
=
innodb
;
create
table
t4
(
a
int
)
engine
=
innodb
;
create
table
t4
(
a
int
)
engine
=
innodb
;
show
variables
like
'slave_transaction_retries'
;
sync_slave_with_master
;
sync_slave_with_master
;
show
create
table
t1
;
show
create
table
t1
;
show
create
table
t2
;
show
create
table
t2
;
show
variables
like
'slave_transaction_retries'
;
stop
slave
;
stop
slave
;
# 1) Test deadlock
# 1) Test deadlock
...
...
sql/mysqld.cc
View file @
32f1e3b0
...
@@ -3134,8 +3134,17 @@ we force server id to 2, but this MySQL server will not act as a slave.");
...
@@ -3134,8 +3134,17 @@ we force server id to 2, but this MySQL server will not act as a slave.");
#endif
#endif
if
(
opt_bootstrap
)
/* If running with bootstrap, do not start replication. */
if
(
opt_bootstrap
)
/* If running with bootstrap, do not start replication. */
opt_skip_slave_start
=
1
;
opt_skip_slave_start
=
1
;
/* init_slave() must be called after the thread keys are created */
/*
init_slave
();
init_slave() must be called after the thread keys are created.
Some parts of the code (e.g. SHOW STATUS LIKE 'slave_running' and other
places) assume that active_mi != 0, so let's fail if it's 0 (out of
memory); a message has already been printed.
*/
if
(
init_slave
()
&&
!
active_mi
)
{
end_thr_alarm
(
1
);
// Don't allow alarms
unireg_abort
(
1
);
}
if
(
opt_bootstrap
)
if
(
opt_bootstrap
)
{
{
...
@@ -5689,7 +5698,8 @@ struct show_var_st status_vars[]= {
...
@@ -5689,7 +5698,8 @@ struct show_var_st status_vars[]= {
{
"Select_range_check"
,
(
char
*
)
offsetof
(
STATUS_VAR
,
select_range_check_count
),
SHOW_LONG_STATUS
},
{
"Select_range_check"
,
(
char
*
)
offsetof
(
STATUS_VAR
,
select_range_check_count
),
SHOW_LONG_STATUS
},
{
"Select_scan"
,
(
char
*
)
offsetof
(
STATUS_VAR
,
select_scan_count
),
SHOW_LONG_STATUS
},
{
"Select_scan"
,
(
char
*
)
offsetof
(
STATUS_VAR
,
select_scan_count
),
SHOW_LONG_STATUS
},
{
"Slave_open_temp_tables"
,
(
char
*
)
&
slave_open_temp_tables
,
SHOW_LONG
},
{
"Slave_open_temp_tables"
,
(
char
*
)
&
slave_open_temp_tables
,
SHOW_LONG
},
{
"Slave_running"
,
(
char
*
)
0
,
SHOW_SLAVE_RUNNING
},
{
"Slave_running"
,
(
char
*
)
0
,
SHOW_SLAVE_RUNNING
},
{
"Slave_retried_transactions"
,(
char
*
)
0
,
SHOW_SLAVE_RETRIED_TRANS
},
{
"Slow_launch_threads"
,
(
char
*
)
&
slow_launch_threads
,
SHOW_LONG
},
{
"Slow_launch_threads"
,
(
char
*
)
&
slow_launch_threads
,
SHOW_LONG
},
{
"Slow_queries"
,
(
char
*
)
offsetof
(
STATUS_VAR
,
long_query_count
),
SHOW_LONG_STATUS
},
{
"Slow_queries"
,
(
char
*
)
offsetof
(
STATUS_VAR
,
long_query_count
),
SHOW_LONG_STATUS
},
{
"Sort_merge_passes"
,
(
char
*
)
offsetof
(
STATUS_VAR
,
filesort_merge_passes
),
SHOW_LONG_STATUS
},
{
"Sort_merge_passes"
,
(
char
*
)
offsetof
(
STATUS_VAR
,
filesort_merge_passes
),
SHOW_LONG_STATUS
},
...
...
sql/slave.cc
View file @
32f1e3b0
...
@@ -27,6 +27,7 @@
...
@@ -27,6 +27,7 @@
#include <my_dir.h>
#include <my_dir.h>
#include <sql_common.h>
#include <sql_common.h>
#define MAX_SLAVE_RETRY_PAUSE 5
bool
use_slave_mask
=
0
;
bool
use_slave_mask
=
0
;
MY_BITMAP
slave_error_mask
;
MY_BITMAP
slave_error_mask
;
...
@@ -2528,7 +2529,7 @@ st_relay_log_info::st_relay_log_info()
...
@@ -2528,7 +2529,7 @@ st_relay_log_info::st_relay_log_info()
ignore_log_space_limit
(
0
),
last_master_timestamp
(
0
),
slave_skip_counter
(
0
),
ignore_log_space_limit
(
0
),
last_master_timestamp
(
0
),
slave_skip_counter
(
0
),
abort_pos_wait
(
0
),
slave_run_id
(
0
),
sql_thd
(
0
),
last_slave_errno
(
0
),
abort_pos_wait
(
0
),
slave_run_id
(
0
),
sql_thd
(
0
),
last_slave_errno
(
0
),
inited
(
0
),
abort_slave
(
0
),
slave_running
(
0
),
until_condition
(
UNTIL_NONE
),
inited
(
0
),
abort_slave
(
0
),
slave_running
(
0
),
until_condition
(
UNTIL_NONE
),
until_log_pos
(
0
)
until_log_pos
(
0
)
,
retried_trans
(
0
)
{
{
group_relay_log_name
[
0
]
=
event_relay_log_name
[
0
]
=
group_relay_log_name
[
0
]
=
event_relay_log_name
[
0
]
=
group_master_log_name
[
0
]
=
0
;
group_master_log_name
[
0
]
=
0
;
...
@@ -3261,9 +3262,8 @@ static int exec_relay_log_event(THD* thd, RELAY_LOG_INFO* rli)
...
@@ -3261,9 +3262,8 @@ static int exec_relay_log_event(THD* thd, RELAY_LOG_INFO* rli)
init_master_info()).
init_master_info()).
b) init_relay_log_pos(), because the BEGIN may be an older relay log.
b) init_relay_log_pos(), because the BEGIN may be an older relay log.
*/
*/
if
(
rli
->
trans_retries
--
)
if
(
rli
->
trans_retries
<
slave_trans_retries
)
{
{
sql_print_information
(
"Slave SQL thread retries transaction"
);
if
(
init_master_info
(
rli
->
mi
,
0
,
0
,
0
,
SLAVE_SQL
))
if
(
init_master_info
(
rli
->
mi
,
0
,
0
,
0
,
SLAVE_SQL
))
sql_print_error
(
"Failed to initialize the master info structure"
);
sql_print_error
(
"Failed to initialize the master info structure"
);
else
if
(
init_relay_log_pos
(
rli
,
else
if
(
init_relay_log_pos
(
rli
,
...
@@ -3275,8 +3275,16 @@ static int exec_relay_log_event(THD* thd, RELAY_LOG_INFO* rli)
...
@@ -3275,8 +3275,16 @@ static int exec_relay_log_event(THD* thd, RELAY_LOG_INFO* rli)
else
else
{
{
exec_res
=
0
;
exec_res
=
0
;
sleep
(
2
);
// chance for concurrent connection to get more locks
/* chance for concurrent connection to get more locks */
}
safe_sleep
(
thd
,
min
(
rli
->
trans_retries
,
MAX_SLAVE_RETRY_PAUSE
),
(
CHECK_KILLED_FUNC
)
sql_slave_killed
,
(
void
*
)
rli
);
pthread_mutex_lock
(
&
rli
->
data_lock
);
// because of SHOW STATUS
rli
->
trans_retries
++
;
rli
->
retried_trans
++
;
pthread_mutex_unlock
(
&
rli
->
data_lock
);
DBUG_PRINT
(
"info"
,
(
"Slave retries transaction "
"rli->trans_retries: %lu"
,
rli
->
trans_retries
));
}
}
}
else
else
sql_print_error
(
"Slave SQL thread retried transaction %lu time(s) "
sql_print_error
(
"Slave SQL thread retried transaction %lu time(s) "
...
@@ -3285,8 +3293,8 @@ static int exec_relay_log_event(THD* thd, RELAY_LOG_INFO* rli)
...
@@ -3285,8 +3293,8 @@ static int exec_relay_log_event(THD* thd, RELAY_LOG_INFO* rli)
slave_trans_retries
);
slave_trans_retries
);
}
}
if
(
!
((
thd
->
options
&
OPTION_BEGIN
)
&&
opt_using_transactions
))
if
(
!
((
thd
->
options
&
OPTION_BEGIN
)
&&
opt_using_transactions
))
rli
->
trans_retries
=
slave_trans_retries
;
// restart from fresh
rli
->
trans_retries
=
0
;
// restart from fresh
}
}
return
exec_res
;
return
exec_res
;
}
}
else
else
...
@@ -3701,7 +3709,7 @@ slave_begin:
...
@@ -3701,7 +3709,7 @@ slave_begin:
pthread_mutex_lock
(
&
rli
->
log_space_lock
);
pthread_mutex_lock
(
&
rli
->
log_space_lock
);
rli
->
ignore_log_space_limit
=
0
;
rli
->
ignore_log_space_limit
=
0
;
pthread_mutex_unlock
(
&
rli
->
log_space_lock
);
pthread_mutex_unlock
(
&
rli
->
log_space_lock
);
rli
->
trans_retries
=
slave_trans_retries
;
// start from "no error"
rli
->
trans_retries
=
0
;
// start from "no error"
if
(
init_relay_log_pos
(
rli
,
if
(
init_relay_log_pos
(
rli
,
rli
->
group_relay_log_name
,
rli
->
group_relay_log_name
,
...
...
sql/slave.h
View file @
32f1e3b0
...
@@ -293,7 +293,14 @@ typedef struct st_relay_log_info
...
@@ -293,7 +293,14 @@ typedef struct st_relay_log_info
}
until_log_names_cmp_result
;
}
until_log_names_cmp_result
;
char
cached_charset
[
6
];
char
cached_charset
[
6
];
ulong
trans_retries
;
/*
trans_retries varies between 0 to slave_transaction_retries and counts how
many times the slave has retried the present transaction; gets reset to 0
when the transaction finally succeeds. retried_trans is a cumulative
counter: how many times the slave has retried a transaction (any) since
slave started.
*/
ulong
trans_retries
,
retried_trans
;
st_relay_log_info
();
st_relay_log_info
();
~
st_relay_log_info
();
~
st_relay_log_info
();
...
...
sql/sql_show.cc
View file @
32f1e3b0
...
@@ -1331,6 +1331,19 @@ static bool show_status_array(THD *thd, const char *wild,
...
@@ -1331,6 +1331,19 @@ static bool show_status_array(THD *thd, const char *wild,
pthread_mutex_unlock
(
&
LOCK_active_mi
);
pthread_mutex_unlock
(
&
LOCK_active_mi
);
break
;
break
;
}
}
case
SHOW_SLAVE_RETRIED_TRANS
:
{
/*
TODO: in 5.1 with multimaster, have one such counter per line in SHOW
SLAVE STATUS, and have the sum over all lines here.
*/
pthread_mutex_lock
(
&
LOCK_active_mi
);
pthread_mutex_lock
(
&
active_mi
->
rli
.
data_lock
);
end
=
int10_to_str
(
active_mi
->
rli
.
retried_trans
,
buff
,
10
);
pthread_mutex_unlock
(
&
active_mi
->
rli
.
data_lock
);
pthread_mutex_unlock
(
&
LOCK_active_mi
);
break
;
}
#endif
/* HAVE_REPLICATION */
#endif
/* HAVE_REPLICATION */
case
SHOW_OPENTABLES
:
case
SHOW_OPENTABLES
:
end
=
int10_to_str
((
long
)
cached_tables
(),
buff
,
10
);
end
=
int10_to_str
((
long
)
cached_tables
(),
buff
,
10
);
...
...
sql/structs.h
View file @
32f1e3b0
...
@@ -182,7 +182,7 @@ enum SHOW_TYPE
...
@@ -182,7 +182,7 @@ enum SHOW_TYPE
SHOW_SSL_CTX_SESS_TIMEOUTS
,
SHOW_SSL_CTX_SESS_CACHE_FULL
,
SHOW_SSL_CTX_SESS_TIMEOUTS
,
SHOW_SSL_CTX_SESS_CACHE_FULL
,
SHOW_SSL_GET_CIPHER_LIST
,
SHOW_SSL_GET_CIPHER_LIST
,
#endif
/* HAVE_OPENSSL */
#endif
/* HAVE_OPENSSL */
SHOW_RPL_STATUS
,
SHOW_SLAVE_RUNNING
,
SHOW_RPL_STATUS
,
SHOW_SLAVE_RUNNING
,
SHOW_SLAVE_RETRIED_TRANS
,
SHOW_KEY_CACHE_LONG
,
SHOW_KEY_CACHE_CONST_LONG
,
SHOW_KEY_CACHE_LONG
,
SHOW_KEY_CACHE_CONST_LONG
,
SHOW_LONG_STATUS
,
SHOW_LONG_CONST_STATUS
SHOW_LONG_STATUS
,
SHOW_LONG_CONST_STATUS
};
};
...
...
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