Commit 3871477c authored by Elena Stepanova's avatar Elena Stepanova

MDEV-10100 main.pool_of_threads fails sporadically in buildbot

The patch fixes two test failures:
- on slow builders, sometimes a connection attempt which should
  fail due to the exceeded number of thread_pool_max_threads
  actually succeeds;
- on even slow builders, MTR sometimes cannot establish the
  initial connection, and check-testcase fails prior to the
  test start

The problem with check-testcase was caused by connect-timeout=2
which was set for all clients in the test config file. On slow
builders it might be not enough.
There is no way to override it for the pre-test check, so it needed
to be substantially increased or removed.

The other problem was caused by a race condition between sleeps
that the test performs in existing connections and the connect
timeout for the connection attempt which was expected to fail.
If sleeps finished before the connect-timeout was exceeded, it
would allow the connection to succeed.

To solve each problem without making the other one worse,
connect-timeout should be configured dynamically during the test.
Due to the nature of the test (all connections must be busy
at the moment when we need to change the timeout, and cannot execute
SET GLOBAL ...), it needs to be done independently from the server.

The solution:
- recognize 'connect_timeout' as a connection option in mysqltest's
  "connect" command;
- remove connect-timeout from the test configuration file;
- use the new connect_timeout option for those connections which
  are expected to fail;
- re-arrange the test flow to allow running a huge SLEEP
  without affecting the test execution time (because it would be
  interrupted after the main test flow is finished).

The test is still subject to false negatives, e.g. if the connection
fails due to timeout rather than due to the exceeded number of
allowed threads, or if the connection on extra port succeeds due
to a race condition and not because the special logic for the extra
port. But those false negatives have always been possible there
on slow builders, they should not be critical because faster builders
should catch such failures if they appear.
parent d02a77bc
...@@ -5945,6 +5945,7 @@ void do_connect(struct st_command *command) ...@@ -5945,6 +5945,7 @@ void do_connect(struct st_command *command)
my_bool con_shm __attribute__ ((unused))= 0; my_bool con_shm __attribute__ ((unused))= 0;
int read_timeout= 0; int read_timeout= 0;
int write_timeout= 0; int write_timeout= 0;
int connect_timeout= 0;
struct st_connection* con_slot; struct st_connection* con_slot;
static DYNAMIC_STRING ds_connection_name; static DYNAMIC_STRING ds_connection_name;
...@@ -6051,6 +6052,11 @@ void do_connect(struct st_command *command) ...@@ -6051,6 +6052,11 @@ void do_connect(struct st_command *command)
{ {
write_timeout= atoi(con_options + sizeof("write_timeout=")-1); write_timeout= atoi(con_options + sizeof("write_timeout=")-1);
} }
else if (strncasecmp(con_options, "connect_timeout=",
sizeof("connect_timeout=")-1) == 0)
{
connect_timeout= atoi(con_options + sizeof("connect_timeout=")-1);
}
else else
die("Illegal option to connect: %.*s", die("Illegal option to connect: %.*s",
(int) (end - con_options), con_options); (int) (end - con_options), con_options);
...@@ -6135,6 +6141,12 @@ void do_connect(struct st_command *command) ...@@ -6135,6 +6141,12 @@ void do_connect(struct st_command *command)
(char*)&write_timeout); (char*)&write_timeout);
} }
if (connect_timeout)
{
mysql_options(con_slot->mysql, MYSQL_OPT_CONNECT_TIMEOUT,
(char*)&connect_timeout);
}
#ifdef HAVE_SMEM #ifdef HAVE_SMEM
if (con_shm) if (con_shm)
{ {
......
...@@ -2157,23 +2157,22 @@ Warnings: ...@@ -2157,23 +2157,22 @@ Warnings:
Warning 1052 Column 'kundentyp' in group statement is ambiguous Warning 1052 Column 'kundentyp' in group statement is ambiguous
drop table t1; drop table t1;
SET optimizer_switch=@save_optimizer_switch; SET optimizer_switch=@save_optimizer_switch;
SELECT sleep(5.5); SELECT sleep(50);
SELECT sleep(5); SELECT sleep(50);
# -- Success: more than --thread_pool_max_threads normal connections not possible # -- Success: more than --thread_pool_max_threads normal connections not possible
sleep(5.5)
0
sleep(5)
0
SELECT sleep(5);
SELECT sleep(5);
SELECT 'Connection on extra port ok'; SELECT 'Connection on extra port ok';
Connection on extra port ok Connection on extra port ok
Connection on extra port ok Connection on extra port ok
SELECT sleep(5.5);
SELECT 'Connection on extra port 2 ok'; SELECT 'Connection on extra port 2 ok';
Connection on extra port 2 ok Connection on extra port 2 ok
Connection on extra port 2 ok Connection on extra port 2 ok
# -- Success: more than --extra-max-connections + 1 normal connections not possible # -- Success: more than --extra-max-connections + 1 normal connections not possible
sleep(5) KILL QUERY <default_connection_ID>;
0 KILL QUERY <con2_connection_ID>;
sleep(5) sleep(50)
1
sleep(50)
1
sleep(5.5)
0 0
...@@ -7,8 +7,5 @@ loose-thread_pool_max_threads= 2 ...@@ -7,8 +7,5 @@ loose-thread_pool_max_threads= 2
extra-port= @ENV.MASTER_EXTRA_PORT extra-port= @ENV.MASTER_EXTRA_PORT
extra-max-connections=1 extra-max-connections=1
[client]
connect-timeout= 2
[ENV] [ENV]
MASTER_EXTRA_PORT= @OPT.port MASTER_EXTRA_PORT= @OPT.port
...@@ -15,23 +15,26 @@ SET optimizer_switch=@save_optimizer_switch; ...@@ -15,23 +15,26 @@ SET optimizer_switch=@save_optimizer_switch;
# connections on the extra port. # connections on the extra port.
# First set two connections running, and check that extra connection # First set two connections running, and check that extra connection
# on normal port fails due to--thread-pool-max_threads=2 # on normal port fails due to --thread-pool-max-threads=2.
# We can afford using a really long sleep, because we won't wait
# till it ends, we'll interrupt it as soon as we don't need it anymore
connection default; connection default;
--let $con1_id= `SELECT CONNECTION_ID()`
# Sleep for slightly longer than 5 sec to trigger MDEV-4566 send SELECT sleep(50);
# (abort in interruptible wait connection check)
send SELECT sleep(5.5);
--sleep 1 --sleep 1
connect(con2,localhost,root,,); connect(con2,localhost,root,,);
connection con2; --let $con2_id= `SELECT CONNECTION_ID()`
send SELECT sleep(5);
send SELECT sleep(50);
--sleep 0.5 --sleep 0.5
--disable_abort_on_error --disable_abort_on_error
--disable_result_log --disable_result_log
--disable_query_log --disable_query_log
connect(con3,localhost,root,,); connect(con3,localhost,root,,,,,connect_timeout=2);
--enable_query_log --enable_query_log
--enable_result_log --enable_result_log
--enable_abort_on_error --enable_abort_on_error
...@@ -45,24 +48,15 @@ if ($error) ...@@ -45,24 +48,15 @@ if ($error)
--echo # -- Success: more than --thread_pool_max_threads normal connections not possible --echo # -- Success: more than --thread_pool_max_threads normal connections not possible
} }
connection default;
--reap
connection con2;
--reap
# Now try again, but this time use the extra port to successfully connect.
connection default;
send SELECT sleep(5);
connection con2;
send SELECT sleep(5);
--sleep 1
connect(extracon,127.0.0.1,root,,test,$MASTER_EXTRA_PORT,); connect(extracon,127.0.0.1,root,,test,$MASTER_EXTRA_PORT,);
connection extracon; connection extracon;
SELECT 'Connection on extra port ok'; SELECT 'Connection on extra port ok';
# Here, sleep just for slightly longer than 5 sec to trigger MDEV-4566
# (abort in interruptible wait connection check).
send SELECT sleep(5.5);
connect(extracon2,127.0.0.1,root,,test,$MASTER_EXTRA_PORT,); connect(extracon2,127.0.0.1,root,,test,$MASTER_EXTRA_PORT,);
connection extracon2; connection extracon2;
SELECT 'Connection on extra port 2 ok'; SELECT 'Connection on extra port 2 ok';
...@@ -70,7 +64,7 @@ SELECT 'Connection on extra port 2 ok'; ...@@ -70,7 +64,7 @@ SELECT 'Connection on extra port 2 ok';
--disable_abort_on_error --disable_abort_on_error
--disable_result_log --disable_result_log
--disable_query_log --disable_query_log
connect(extracon3,127.0.0.1,root,,test,$MASTER_EXTRA_PORT,); connect(extracon3,127.0.0.1,root,,test,$MASTER_EXTRA_PORT,,connect_timeout=2);
--enable_query_log --enable_query_log
--enable_result_log --enable_result_log
--enable_abort_on_error --enable_abort_on_error
...@@ -84,7 +78,16 @@ if ($error) ...@@ -84,7 +78,16 @@ if ($error)
--echo # -- Success: more than --extra-max-connections + 1 normal connections not possible --echo # -- Success: more than --extra-max-connections + 1 normal connections not possible
} }
connection extracon2;
--replace_result $con1_id <default_connection_ID>
eval KILL QUERY $con1_id;
--replace_result $con2_id <con2_connection_ID>
eval KILL QUERY $con2_id;
connection default; connection default;
--reap --reap
connection con2; connection con2;
--reap --reap
connection extracon;
--reap
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment