forked from facebook/mysql-5.6
-
Notifications
You must be signed in to change notification settings - Fork 3
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
[thread_pool] Call thd_wait_* callbacks for admitting new query in th…
…read pool plugin Summary: 1. Change the code to admit new query through `thd_wait_begin/end` callbacks using new `THD_WAIT_ADMIT` wait type. 2. Move yield counting to the callbacks to unify the code between the server and the plugin. `yield_cond` exposes the yield condition to check once the yield counter says that yield is needed. 3. Expose all wait events through `admission_control_wait_events` var. This is especially needed for `USER_LOCK` which still controls innodb thread concurrency yield. 4. Copy and fix up admission control tests to the thread_pool suite. Only the var and table names are changed to refer to thread_pool plugin. The results have been diffed with original tests to make sure they are identical (except for var/table names). Reviewed By: lth Differential Revision: D27593084 --------------------------------------------------------------------------------------------- use lambda instead of std::bind (facebook#1243) Summary: std::bind(yield_condition, table) will generate a functor which size is larger than std::function's local buf, thus std::function needs to new/delete memory to store the functor. This PR use the lambda which just capture one pointer(table), which size can fit into std::function's local buf thus new/delete is not needed. Pull Request resolved: facebook#1243 Reviewed By: lth Differential Revision: D40858532 Pulled By: hermanlee fbshipit-source-id: f7431f7
- Loading branch information
1 parent
0e9f215
commit 696ecb6
Showing
36 changed files
with
2,218 additions
and
60 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
160 changes: 160 additions & 0 deletions
160
mysql-test/suite/thread_pool/r/admission_control.result
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,160 @@ | ||
create database test_db; | ||
create database test_db2; | ||
create user 'test_user'@'localhost'; | ||
grant all on test_db.* to 'test_user'@'localhost'; | ||
grant all on test_db2.* to 'test_user'@'localhost'; | ||
grant all on test.* to 'test_user'@'localhost'; | ||
use test_db2; | ||
use test_db; | ||
set @start_max_running_queries= @@global.thread_pool_max_running_queries; | ||
set @start_max_waiting_queries= @@global.thread_pool_max_waiting_queries; | ||
set @@global.thread_pool_max_running_queries=10; | ||
set @@global.thread_pool_max_waiting_queries=5; | ||
create table t1(a int) engine=InnoDB; | ||
lock table t1 write; | ||
Threads waiting for admission will have appropriate state set in processlist. | ||
Super user is exempted from admission control checks. | ||
select * from t1; | ||
a | ||
set @@global.thread_pool_admission_control_filter = 'USE'; | ||
select @@global.thread_pool_admission_control_filter; | ||
@@global.thread_pool_admission_control_filter | ||
USE | ||
Maximum waiting queries reached. So this would hit an error. | ||
use test_db; | ||
select * from t1|||| | ||
ERROR HY000: Maximum waiting queries 5 reached for database `test_db` | ||
Maximum waiting queries reached. So this would hit an error. | ||
use test_db2; | ||
create table t1_test(aaa int); | ||
insert into t1_test values (1); | ||
select aaa from t1_test; | ||
drop table t1_test; | ||
use test_db; | ||
select * from t1|||| | ||
aaa | ||
1 | ||
ERROR HY000: Maximum waiting queries 5 reached for database `test_db` | ||
use test_db; | ||
select * from t1; | ||
ERROR HY000: Maximum waiting queries 5 reached for database `test_db` | ||
set @@global.thread_pool_admission_control_filter = ''; | ||
select @@global.thread_pool_admission_control_filter; | ||
@@global.thread_pool_admission_control_filter | ||
|
||
Check status variables | ||
aborted_queries = 3 | ||
running_queries = 10 | ||
waiting_queries = 5 | ||
select * from information_schema.tp_admission_control_entities where schema_name like 'test_db%' order by schema_name; | ||
SCHEMA_NAME WAITING_QUERIES RUNNING_QUERIES ABORTED_QUERIES TIMEOUT_QUERIES CONNECTIONS REJECTED_CONNECTIONS | ||
test_db 5 10 3 0 15 0 | ||
test_db2 0 0 0 0 0 0 | ||
Filled up queues on one db doesn't affect queries on other db. | ||
use test_db2; | ||
select * from information_schema.tp_admission_control_entities where schema_name like 'test_db%' order by schema_name; | ||
SCHEMA_NAME WAITING_QUERIES RUNNING_QUERIES ABORTED_QUERIES TIMEOUT_QUERIES CONNECTIONS REJECTED_CONNECTIONS | ||
test_db 5 10 3 0 15 0 | ||
test_db2 0 1 0 0 1 0 | ||
set @@global.thread_pool_max_waiting_queries=6; | ||
Kill a thread that is waiting for admission. | ||
select count(*) from t1; | ||
kill ID; | ||
use test_db; | ||
unlock tables; | ||
Verify the waiting queries received wakeup signal. | ||
select count(*) from t1; | ||
count(*) | ||
15 | ||
set @save_admission_control_by_trx = @@global.thread_pool_admission_control_by_trx; | ||
select @save_admission_control_by_trx; | ||
@save_admission_control_by_trx | ||
0 | ||
set @@global.thread_pool_max_running_queries=5; | ||
set @@global.thread_pool_max_waiting_queries=10; | ||
# By default, open transaction has no effect on running queries | ||
select count(*) from t1; | ||
count(*) | ||
15 | ||
# Test: open transactions will take slots in running queries, | ||
# and will not be blocked | ||
set @@global.thread_pool_admission_control_filter = 'BEGIN,COMMIT,ROLLBACK'; | ||
select @@global.thread_pool_admission_control_filter; | ||
@@global.thread_pool_admission_control_filter | ||
BEGIN,COMMIT,ROLLBACK | ||
set @@global.thread_pool_admission_control_by_trx = true; | ||
SELECT @@global.thread_pool_admission_control_by_trx; | ||
@@global.thread_pool_admission_control_by_trx | ||
1 | ||
Open transaction is able to continue running queries | ||
connection con_max_wait; | ||
New queries will be rejected (waiting queue is full) | ||
select * from t1; | ||
ERROR HY000: Maximum waiting queries 10 reached for database `test_db` | ||
New transactions will be rejected (waiting queue is full) | ||
begin; | ||
select * from t1; | ||
ERROR HY000: Maximum waiting queries 10 reached for database `test_db` | ||
aborted_queries will increase by 2 | ||
Committing a transaction will free up the running query slots | ||
The waiting queries will be unblocked | ||
Check status variables | ||
include/assert.inc [DB Admission control waiting queries should be zero] | ||
include/assert.inc [DB Admission control running queries should be zero] | ||
include/assert.inc [DB Admission control aborted queries should be five] | ||
select * from information_schema.tp_admission_control_entities where schema_name like 'test_db%' order by schema_name; | ||
SCHEMA_NAME WAITING_QUERIES RUNNING_QUERIES ABORTED_QUERIES TIMEOUT_QUERIES CONNECTIONS REJECTED_CONNECTIONS | ||
test_db 0 0 5 0 13 0 | ||
test_db2 0 0 0 0 0 0 | ||
set @@global.thread_pool_admission_control_by_trx = @save_admission_control_by_trx; | ||
select @@global.thread_pool_admission_control_by_trx; | ||
@@global.thread_pool_admission_control_by_trx | ||
0 | ||
set @@global.thread_pool_admission_control_filter = ''; | ||
select @@global.thread_pool_admission_control_filter; | ||
@@global.thread_pool_admission_control_filter | ||
|
||
# End of open transaction test | ||
# Test admission_control_queue_timeout | ||
use test_db; | ||
set @@global.thread_pool_max_running_queries=1; | ||
set @@global.thread_pool_max_waiting_queries=5; | ||
set @save_admission_control_filter = @@global.thread_pool_admission_control_filter; | ||
set @save_admission_control_queue_timeout = @@global.thread_pool_admission_control_queue_timeout; | ||
set @@global.thread_pool_admission_control_queue_timeout = 100; | ||
set @@global.thread_pool_admission_control_filter = 'BEGIN,COMMIT,ROLLBACK'; | ||
create table t2(a int primary key) engine=InnoDB; | ||
begin; | ||
insert into t2 values (1); | ||
begin; | ||
insert into t2 values (1); | ||
insert into t2 values (2); | ||
ERROR HY000: Got timeout while waiting on admission control queue for database `test_db` | ||
rollback; | ||
rollback; | ||
drop table t2; | ||
set @@global.thread_pool_admission_control_filter = @save_admission_control_filter; | ||
set @@global.thread_pool_admission_control_queue_timeout = @save_admission_control_queue_timeout; | ||
timeout_queries should be 1 | ||
timeout_queries = 1 | ||
waiting_queries should be 0 | ||
waiting_queries = 0 | ||
select * from information_schema.tp_admission_control_entities where schema_name like 'test_db%' order by schema_name; | ||
SCHEMA_NAME WAITING_QUERIES RUNNING_QUERIES ABORTED_QUERIES TIMEOUT_QUERIES CONNECTIONS REJECTED_CONNECTIONS | ||
test_db 0 0 5 1 15 0 | ||
test_db2 0 0 0 0 0 0 | ||
reset global.thread_pool_max_running_queries and global.thread_pool_max_waiting_queries | ||
set @@global.thread_pool_max_running_queries=10; | ||
set @@global.thread_pool_max_waiting_queries=5; | ||
Run parallel load and drop the database. | ||
set @@global.thread_pool_max_waiting_queries=0; | ||
Cleanup. | ||
Verify there are no waiting threads. | ||
select count(*) from information_schema.processlist where state='waiting for admission'; | ||
count(*) | ||
0 | ||
select * from information_schema.tp_admission_control_entities where schema_name like 'test_db%' order by schema_name; | ||
SCHEMA_NAME WAITING_QUERIES RUNNING_QUERIES ABORTED_QUERIES TIMEOUT_QUERIES CONNECTIONS REJECTED_CONNECTIONS | ||
set @@global.thread_pool_max_running_queries=@start_max_running_queries; | ||
set @@global.thread_pool_max_waiting_queries=@start_max_waiting_queries; | ||
drop user test_user@localhost; |
93 changes: 93 additions & 0 deletions
93
mysql-test/suite/thread_pool/r/admission_control_hang.result
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,93 @@ | ||
create database test_db; | ||
create user test_user@localhost; | ||
grant all on test_db.* to test_user@localhost; | ||
set @start_max_running_queries = @@global.max_running_queries; | ||
set @@global.max_running_queries = 4; | ||
set @start_innodb_lock_wait_timeout = @@global.innodb_lock_wait_timeout; | ||
set @@global.innodb_lock_wait_timeout = 10000; | ||
set @start_admission_control_filter = @@global.admission_control_filter; | ||
set @@global.admission_control_filter = 'COMMIT'; | ||
create table t1 (a int) engine=innodb; | ||
insert into t1 values(1); | ||
begin; | ||
update t1 set a=2 where a=1; | ||
update t1 set a=2 where a=1; | ||
update t1 set a=2 where a=1; | ||
update t1 set a=2 where a=1; | ||
update t1 set a=2 where a=1; | ||
set @@global.admission_control_filter = 'USE'; | ||
select @@global.admission_control_filter; | ||
@@global.admission_control_filter | ||
USE | ||
use test; | ||
use test_db; | ||
set @@global.admission_control_filter = 'ALTER,BEGIN,COMMIT,CREATE,DELETE,DROP,INSERT,LOAD,SELECT,SET,REPLACE,TRUNCATE,UPDATE,SHOW,ROLLBACK'; | ||
select @@global.admission_control_filter; | ||
@@global.admission_control_filter | ||
ALTER,BEGIN,COMMIT,CREATE,DELETE,DROP,INSERT,LOAD,SELECT,SET,REPLACE,ROLLBACK,TRUNCATE,UPDATE,SHOW | ||
create table t2(a int) engine=innodb; | ||
begin; | ||
insert into t2 values(1); | ||
update t2 set a=2 where a=1; | ||
commit; | ||
SHOW TABLES LIKE 't2'; | ||
Tables_in_test_db (t2) | ||
t2 | ||
begin; | ||
alter table t2 rename t3; | ||
select * from t3; | ||
a | ||
2 | ||
delete from t3; | ||
set @val = 1; | ||
truncate table t3; | ||
rollback; | ||
drop table t3; | ||
set @save_admission_control_by_trx = @@global.admission_control_by_trx; | ||
select @save_admission_control_by_trx; | ||
@save_admission_control_by_trx | ||
0 | ||
# Turn on admission_control_by_trx | ||
set @@global.admission_control_by_trx = true; | ||
SELECT @@global.admission_control_by_trx; | ||
@@global.admission_control_by_trx | ||
1 | ||
create table t2(a int) engine=innodb; | ||
begin; | ||
insert into t2 values(1); | ||
update t2 set a=2 where a=1; | ||
commit; | ||
SHOW TABLES LIKE 't2'; | ||
Tables_in_test_db (t2) | ||
t2 | ||
begin; | ||
alter table t2 rename t3; | ||
select * from t3; | ||
a | ||
2 | ||
delete from t3; | ||
set @val = 1; | ||
truncate table t3; | ||
rollback; | ||
drop table t3; | ||
set @@global.admission_control_filter = default; | ||
select @@global.admission_control_filter; | ||
@@global.admission_control_filter | ||
|
||
select count(*) from t1; | ||
count(*) | ||
1 | ||
set @@global.admission_control_by_trx = @save_admission_control_by_trx; | ||
select @@global.admission_control_by_trx; | ||
@@global.admission_control_by_trx | ||
0 | ||
set @@global.admission_control_filter = 'COMMIT'; | ||
select @@global.admission_control_filter; | ||
@@global.admission_control_filter | ||
COMMIT | ||
commit; | ||
set @@global.max_running_queries = @start_max_running_queries; | ||
set @@global.innodb_lock_wait_timeout = @start_innodb_lock_wait_timeout; | ||
set @@global.admission_control_filter = @start_admission_control_filter; | ||
drop database test_db; | ||
drop user test_user@localhost; |
8 changes: 8 additions & 0 deletions
8
mysql-test/suite/thread_pool/r/admission_control_multi_query.result
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,8 @@ | ||
create database test_db; | ||
create user test_user@localhost identified with 'mysql_native_password' BY ''; | ||
grant all on test_db.* to test_user@localhost; | ||
grant all on test.* to test_user@localhost; | ||
use test_db; | ||
create table t1 (a int primary key, b int) engine=InnoDB; | ||
drop database test_db; | ||
drop user test_user@localhost; |
8 changes: 8 additions & 0 deletions
8
mysql-test/suite/thread_pool/r/admission_control_multi_query_wait_events.result
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,8 @@ | ||
create database test_db; | ||
create user test_user@localhost identified with 'mysql_native_password' BY ''; | ||
grant all on test_db.* to test_user@localhost; | ||
grant all on test.* to test_user@localhost; | ||
use test_db; | ||
create table t1 (a int primary key, b int) engine=InnoDB; | ||
drop database test_db; | ||
drop user test_user@localhost; |
8 changes: 8 additions & 0 deletions
8
mysql-test/suite/thread_pool/r/admission_control_multi_query_weighted.result
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,8 @@ | ||
create database test_db; | ||
create user test_user@localhost identified with 'mysql_native_password' BY ''; | ||
grant all on test_db.* to test_user@localhost; | ||
grant all on test.* to test_user@localhost; | ||
use test_db; | ||
create table t1 (a int primary key, b int) engine=InnoDB; | ||
drop database test_db; | ||
drop user test_user@localhost; |
Oops, something went wrong.