mirror of
https://github.com/MariaDB/server.git
synced 2025-02-01 19:41:47 +01:00
69cfd5c8ec
Conflicts: - client/mysqltest.cc - mysql-test/collections/default.experimental - mysql-test/suite/rpl/t/disabled.def - sql/mysqld.cc - sql/opt_range.cc - sql/sp.cc - sql/sql_acl.cc - sql/sql_partition.cc - sql/sql_table.cc
191 lines
5.6 KiB
Text
191 lines
5.6 KiB
Text
#
|
|
# BUG#23300: Slow query log on slave does not log slow replicated statements
|
|
#
|
|
# Description:
|
|
# The slave should log slow queries replicated from master when
|
|
# --log-slow-slave-statements is used.
|
|
#
|
|
# Test is implemented as follows:
|
|
# i) stop slave
|
|
# ii) On slave, set long_query_time to a small value.
|
|
# ii) start slave so that long_query_time variable is picked by sql thread
|
|
# iii) On master, do one short time query and one long time query, on slave
|
|
# and check that slow query is logged to slow query log but fast query
|
|
# is not.
|
|
# iv) On slave, check that slow queries go into the slow log and fast dont,
|
|
# when issued through a regular client connection
|
|
# v) On slave, check that slow queries go into the slow log and fast dont
|
|
# when we use SET TIMESTAMP= 1 on a regular client connection.
|
|
# vi) check that when setting slow_query_log= OFF in a connection 'extra2'
|
|
# prevents logging slow queries in a connection 'extra'
|
|
#
|
|
# OBS:
|
|
# This test only runs for statement binlogging format because on row format
|
|
# slow queries do not get slow query logged.
|
|
# Note that due to the sleep() command the insert is written to the binary
|
|
# log in row format.
|
|
|
|
source include/master-slave.inc;
|
|
source include/have_binlog_format_statement.inc;
|
|
|
|
|
|
# Prepare slave for different long_query_time we need to stop the slave
|
|
# and restart it as long_query_time variable is dynamic and, after
|
|
# setting it, it only takes effect on new connections.
|
|
#
|
|
# Reference:
|
|
# http://dev.mysql.com/doc/refman/6.0/en/set-option.html
|
|
connection slave;
|
|
|
|
source include/stop_slave.inc;
|
|
|
|
SET @old_log_output= @@log_output;
|
|
SET GLOBAL log_output= 'TABLE';
|
|
SET @old_long_query_time= @@long_query_time;
|
|
SET GLOBAL long_query_time= 2;
|
|
TRUNCATE mysql.slow_log;
|
|
|
|
source include/start_slave.inc;
|
|
|
|
connection master;
|
|
CREATE TABLE t1 (a int, b int);
|
|
|
|
# test:
|
|
# check that slave logs the slow query to the slow log, but not the fast one.
|
|
|
|
let $slow_query= INSERT INTO t1 values(1, sleep(3));
|
|
let $fast_query= INSERT INTO t1 values(1, 1);
|
|
|
|
eval $fast_query;
|
|
--disable_warnings
|
|
eval $slow_query;
|
|
--enable_warnings
|
|
sync_slave_with_master;
|
|
|
|
let $found_fast_query= `SELECT count(*) = 1 FROM mysql.slow_log WHERE sql_text like '$fast_query'`;
|
|
let $found_slow_query= `SELECT count(*) = 1 FROM mysql.slow_log WHERE sql_text like '$slow_query'`;
|
|
|
|
if ($found_fast_query)
|
|
{
|
|
SELECT * FROM mysql.slow_log;
|
|
die "Assertion failed! Fast query FOUND in slow query log. Bailing out!";
|
|
}
|
|
|
|
if (!$found_slow_query)
|
|
{
|
|
SELECT * FROM mysql.slow_log;
|
|
die "Assertion failed! Slow query NOT FOUND in slow query log. Bailing out!";
|
|
}
|
|
TRUNCATE mysql.slow_log;
|
|
|
|
# regular checks for slow query log (using a new connection - 'extra' - to slave)
|
|
|
|
# test:
|
|
# when using direct connections to the slave, check that slow query is logged
|
|
# but not the fast one.
|
|
|
|
connect(extra,127.0.0.1,root,,test,$SLAVE_MYPORT);
|
|
connection extra;
|
|
|
|
let $fast_query= SELECT 1;
|
|
let $slow_query= SELECT 1, sleep(3);
|
|
|
|
eval $slow_query;
|
|
eval $fast_query;
|
|
|
|
let $found_fast_query= `SELECT count(*) = 1 FROM mysql.slow_log WHERE sql_text like '$fast_query'`;
|
|
let $found_slow_query= `SELECT count(*) = 1 FROM mysql.slow_log WHERE sql_text like '$slow_query'`;
|
|
|
|
if ($found_fast_query)
|
|
{
|
|
SELECT * FROM mysql.slow_log;
|
|
die "Assertion failed! Fast query FOUND in slow query log. Bailing out!";
|
|
}
|
|
|
|
if (!$found_slow_query)
|
|
{
|
|
SELECT * FROM mysql.slow_log;
|
|
die "Assertion failed! Slow query NOT FOUND in slow query log. Bailing out!";
|
|
}
|
|
TRUNCATE mysql.slow_log;
|
|
|
|
# test:
|
|
# when using direct connections to the slave, check that when setting timestamp to 1 the
|
|
# slow query is logged but the fast one is not.
|
|
|
|
let $fast_query= SELECT 2;
|
|
let $slow_query= SELECT 2, sleep(3);
|
|
|
|
SET TIMESTAMP= 1;
|
|
eval $slow_query;
|
|
eval $fast_query;
|
|
|
|
let $found_fast_query= `SELECT count(*) = 1 FROM mysql.slow_log WHERE sql_text like '$fast_query'`;
|
|
let $found_slow_query= `SELECT count(*) = 1 FROM mysql.slow_log WHERE sql_text like '$slow_query'`;
|
|
|
|
if ($found_fast_query)
|
|
{
|
|
SELECT * FROM mysql.slow_log;
|
|
die "Assertion failed! Fast query FOUND in slow query log. Bailing out!";
|
|
}
|
|
|
|
if (!$found_slow_query)
|
|
{
|
|
SELECT * FROM mysql.slow_log;
|
|
die "Assertion failed! Slow query NOT FOUND in slow query log. Bailing out!";
|
|
}
|
|
TRUNCATE mysql.slow_log;
|
|
|
|
# test:
|
|
# check that when setting the slow_query_log= OFF on connection 'extra2'
|
|
# prevents connection 'extra' from logging to slow query log.
|
|
|
|
let $fast_query= SELECT 3;
|
|
let $slow_query= SELECT 3, sleep(3);
|
|
|
|
connect(extra2,127.0.0.1,root,,test,$SLAVE_MYPORT);
|
|
connection extra2;
|
|
|
|
SET @old_slow_query_log= @@slow_query_log;
|
|
SET GLOBAL slow_query_log= 'OFF';
|
|
|
|
connection extra;
|
|
|
|
eval $slow_query;
|
|
eval $fast_query;
|
|
|
|
let $found_fast_query= `SELECT count(*) = 1 FROM mysql.slow_log WHERE sql_text like '$fast_query'`;
|
|
let $found_slow_query= `SELECT count(*) = 1 FROM mysql.slow_log WHERE sql_text like '$slow_query'`;
|
|
|
|
if ($found_fast_query)
|
|
{
|
|
SELECT * FROM mysql.slow_log;
|
|
die "Assertion failed! Fast query FOUND in slow query log when slow_query_log= OFF. Bailing out!";
|
|
}
|
|
|
|
if ($found_slow_query)
|
|
{
|
|
SELECT * FROM mysql.slow_log;
|
|
die "Assertion failed! Slow query FOUND in slow query log when slow_query_log= OFF. Bailing out!";
|
|
}
|
|
TRUNCATE mysql.slow_log;
|
|
|
|
# clean up: drop tables, reset the variables back to the previous value,
|
|
# disconnect extra connections
|
|
connection extra2;
|
|
|
|
SET GLOBAL slow_query_log= @old_slow_query_log;
|
|
|
|
connection master;
|
|
DROP TABLE t1;
|
|
sync_slave_with_master;
|
|
|
|
source include/stop_slave.inc;
|
|
|
|
SET GLOBAL long_query_time= @old_long_query_time;
|
|
SET GLOBAL log_output= @old_log_output;
|
|
|
|
source include/start_slave.inc;
|
|
|
|
disconnect extra;
|
|
disconnect extra2;
|