diff options
| author | Etsuro Fujita | 2021-03-31 09:45:00 +0000 |
|---|---|---|
| committer | Etsuro Fujita | 2021-03-31 09:45:00 +0000 |
| commit | 27e1f14563cf982f1f4d71e21ef247866662a052 (patch) | |
| tree | 4e1a17a61abbfc67a471760cc84e1e46182bfb9d /src/test | |
| parent | 66392d396508c91c2ec07a61568bf96acb663ad8 (diff) | |
Add support for asynchronous execution.
This implements asynchronous execution, which runs multiple parts of a
non-parallel-aware Append concurrently rather than serially to improve
performance when possible. Currently, the only node type that can be
run concurrently is a ForeignScan that is an immediate child of such an
Append. In the case where such ForeignScans access data on different
remote servers, this would run those ForeignScans concurrently, and
overlap the remote operations to be performed simultaneously, so it'll
improve the performance especially when the operations involve
time-consuming ones such as remote join and remote aggregation.
We may extend this to other node types such as joins or aggregates over
ForeignScans in the future.
This also adds the support for postgres_fdw, which is enabled by the
table-level/server-level option "async_capable". The default is false.
Robert Haas, Kyotaro Horiguchi, Thomas Munro, and myself. This commit
is mostly based on the patch proposed by Robert Haas, but also uses
stuff from the patch proposed by Kyotaro Horiguchi and from the patch
proposed by Thomas Munro. Reviewed by Kyotaro Horiguchi, Konstantin
Knizhnik, Andrey Lepikhov, Movead Li, Thomas Munro, Justin Pryzby, and
others.
Discussion: https://postgr.es/m/CA%2BTgmoaXQEt4tZ03FtQhnzeDEMzBck%2BLrni0UWHVVgOTnA6C1w%40mail.gmail.com
Discussion: https://postgr.es/m/CA%2BhUKGLBRyu0rHrDCMC4%3DRn3252gogyp1SjOgG8SEKKZv%3DFwfQ%40mail.gmail.com
Discussion: https://postgr.es/m/20200228.170650.667613673625155850.horikyota.ntt%40gmail.com
Diffstat (limited to 'src/test')
| -rw-r--r-- | src/test/regress/expected/explain.out | 7 | ||||
| -rw-r--r-- | src/test/regress/expected/incremental_sort.out | 2 | ||||
| -rw-r--r-- | src/test/regress/expected/insert_conflict.out | 4 | ||||
| -rw-r--r-- | src/test/regress/expected/sysviews.out | 3 |
4 files changed, 14 insertions, 2 deletions
diff --git a/src/test/regress/expected/explain.out b/src/test/regress/expected/explain.out index 791eba85111..b89b99fb020 100644 --- a/src/test/regress/expected/explain.out +++ b/src/test/regress/expected/explain.out @@ -87,6 +87,7 @@ select explain_filter('explain (analyze, buffers, format json) select * from int "Plan": { + "Node Type": "Seq Scan", + "Parallel Aware": false, + + "Async Capable": false, + "Relation Name": "int8_tbl",+ "Alias": "i8", + "Startup Cost": N.N, + @@ -136,6 +137,7 @@ select explain_filter('explain (analyze, buffers, format xml) select * from int8 <Plan> + <Node-Type>Seq Scan</Node-Type> + <Parallel-Aware>false</Parallel-Aware> + + <Async-Capable>false</Async-Capable> + <Relation-Name>int8_tbl</Relation-Name> + <Alias>i8</Alias> + <Startup-Cost>N.N</Startup-Cost> + @@ -183,6 +185,7 @@ select explain_filter('explain (analyze, buffers, format yaml) select * from int - Plan: + Node Type: "Seq Scan" + Parallel Aware: false + + Async Capable: false + Relation Name: "int8_tbl"+ Alias: "i8" + Startup Cost: N.N + @@ -233,6 +236,7 @@ select explain_filter('explain (buffers, format json) select * from int8_tbl i8' "Plan": { + "Node Type": "Seq Scan", + "Parallel Aware": false, + + "Async Capable": false, + "Relation Name": "int8_tbl",+ "Alias": "i8", + "Startup Cost": N.N, + @@ -346,6 +350,7 @@ select jsonb_pretty( "Actual Rows": 0, + "Actual Loops": 0, + "Startup Cost": 0.0, + + "Async Capable": false, + "Relation Name": "tenk1", + "Parallel Aware": true, + "Local Hit Blocks": 0, + @@ -391,6 +396,7 @@ select jsonb_pretty( "Actual Rows": 0, + "Actual Loops": 0, + "Startup Cost": 0.0, + + "Async Capable": false, + "Parallel Aware": false, + "Sort Space Used": 0, + "Local Hit Blocks": 0, + @@ -433,6 +439,7 @@ select jsonb_pretty( "Actual Rows": 0, + "Actual Loops": 0, + "Startup Cost": 0.0, + + "Async Capable": false, + "Parallel Aware": false, + "Workers Planned": 0, + "Local Hit Blocks": 0, + diff --git a/src/test/regress/expected/incremental_sort.out b/src/test/regress/expected/incremental_sort.out index 68ca321163b..a417b566d95 100644 --- a/src/test/regress/expected/incremental_sort.out +++ b/src/test/regress/expected/incremental_sort.out @@ -558,6 +558,7 @@ select jsonb_pretty(explain_analyze_inc_sort_nodes_without_memory('select * from "Node Type": "Incremental Sort", + "Actual Rows": 55, + "Actual Loops": 1, + + "Async Capable": false, + "Presorted Key": [ + "t.a" + ], + @@ -760,6 +761,7 @@ select jsonb_pretty(explain_analyze_inc_sort_nodes_without_memory('select * from "Node Type": "Incremental Sort", + "Actual Rows": 70, + "Actual Loops": 1, + + "Async Capable": false, + "Presorted Key": [ + "t.a" + ], + diff --git a/src/test/regress/expected/insert_conflict.out b/src/test/regress/expected/insert_conflict.out index ff157ceb1c1..499245068a5 100644 --- a/src/test/regress/expected/insert_conflict.out +++ b/src/test/regress/expected/insert_conflict.out @@ -204,6 +204,7 @@ explain (costs off, format json) insert into insertconflicttest values (0, 'Bilb "Node Type": "ModifyTable", + "Operation": "Insert", + "Parallel Aware": false, + + "Async Capable": false, + "Relation Name": "insertconflicttest", + "Alias": "insertconflicttest", + "Conflict Resolution": "UPDATE", + @@ -213,7 +214,8 @@ explain (costs off, format json) insert into insertconflicttest values (0, 'Bilb { + "Node Type": "Result", + "Parent Relationship": "Member", + - "Parallel Aware": false + + "Parallel Aware": false, + + "Async Capable": false + } + ] + } + diff --git a/src/test/regress/expected/sysviews.out b/src/test/regress/expected/sysviews.out index 6d048e309cb..98dde452e62 100644 --- a/src/test/regress/expected/sysviews.out +++ b/src/test/regress/expected/sysviews.out @@ -95,6 +95,7 @@ select count(*) = 0 as ok from pg_stat_wal_receiver; select name, setting from pg_settings where name like 'enable%'; name | setting --------------------------------+--------- + enable_async_append | on enable_bitmapscan | on enable_gathermerge | on enable_hashagg | on @@ -113,7 +114,7 @@ select name, setting from pg_settings where name like 'enable%'; enable_seqscan | on enable_sort | on enable_tidscan | on -(18 rows) +(19 rows) -- Test that the pg_timezone_names and pg_timezone_abbrevs views are -- more-or-less working. We can't test their contents in any great detail |
