mirror of
https://github.com/MariaDB/server.git
synced 2025-02-01 03:21:53 +01:00
5dcb0e447f
Conflicts: Text conflict in .bzr-mysql/default.conf Text conflict in mysql-test/extra/rpl_tests/rpl_loaddata.test Text conflict in mysql-test/r/mysqlbinlog2.result Text conflict in mysql-test/suite/binlog/r/binlog_stm_mix_innodb_myisam.result Text conflict in mysql-test/suite/binlog/r/binlog_unsafe.result Text conflict in mysql-test/suite/rpl/r/rpl_insert_id.result Text conflict in mysql-test/suite/rpl/r/rpl_loaddata.result Text conflict in mysql-test/suite/rpl/r/rpl_stm_auto_increment_bug33029.result Text conflict in mysql-test/suite/rpl/r/rpl_udf.result Text conflict in mysql-test/suite/rpl/t/rpl_slow_query_log.test Text conflict in sql/field.h Text conflict in sql/log.cc Text conflict in sql/log_event.cc Text conflict in sql/log_event_old.cc Text conflict in sql/mysql_priv.h Text conflict in sql/share/errmsg.txt Text conflict in sql/sp.cc Text conflict in sql/sql_acl.cc Text conflict in sql/sql_base.cc Text conflict in sql/sql_class.h Text conflict in sql/sql_db.cc Text conflict in sql/sql_delete.cc Text conflict in sql/sql_insert.cc Text conflict in sql/sql_lex.cc Text conflict in sql/sql_lex.h Text conflict in sql/sql_load.cc Text conflict in sql/sql_table.cc Text conflict in sql/sql_update.cc Text conflict in sql/sql_view.cc Conflict adding files to storage/innobase. Created directory. Conflict because storage/innobase is not versioned, but has versioned children. Versioned directory. Conflict adding file storage/innobase. Moved existing file to storage/innobase.moved. Conflict adding files to storage/innobase/handler. Created directory. Conflict because storage/innobase/handler is not versioned, but has versioned children. Versioned directory. Contents conflict in storage/innobase/handler/ha_innodb.cc
193 lines
5.7 KiB
Text
193 lines
5.7 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;
|
|
|
|
CALL mtr.add_suppression("Unsafe statement binlogged in statement format since BINLOG_FORMAT = STATEMENT");
|
|
|
|
|
|
# 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;
|