官术网_书友最值得收藏!

  • Mastering PostgreSQL 9.6
  • Hans Jurgen Schonig
  • 221字
  • 2021-07-09 19:57:11

Introducing parallel queries

Traditionally, a query had to run on a single CPU. While this was just fine in the OLTP world, it started to be a problem for analytical applications, which were bound to the speed provided by a single core. With PostgreSQL 9.6, parallel queries were introduced. Of course, implementing parallel queries was hard and so a lot of infrastructure has already been implemented over the years. All this infrastructure is now available to provide the end user with parallel sequential scans. The idea is to make many CPUs work on complicated WHERE conditions during a sequential scan. Version 9.6 also allowed for parallel aggregates and parallel joins. Of course, there is a lot of work left, but we are already looking at a major leap forward.

To control parallelism, there are two essential settings:

test=# SHOW max_worker_processes; 
max_worker_processes
----------------------
8
(1 row)

test=# SHOW max_parallel_workers_per_gather ;
max_parallel_workers_per_gather
---------------------------------
2
(1 row)

The first one limits the overall number of worker processes available. The second one controls the number of workers allowed per gather node.

A gather node is a new thing you will see in an execution plan. It is in charge of unifying results coming from parallel subprocesses.

In addition to those fundamental settings, there are a couple of new optimizer parameters to adjust the cost of parallel queries.

主站蜘蛛池模板: 新乡县| 东莞市| 新宁县| 鲜城| 南京市| 东明县| 建昌县| 津南区| 沾益县| 新泰市| 浦东新区| 大丰市| 宝坻区| 治多县| 西安市| 福清市| 永昌县| 乌兰察布市| 菏泽市| 板桥市| 遂昌县| 林西县| 会同县| 平谷区| 江源县| 淄博市| 宁强县| 靖安县| 龙州县| 玛纳斯县| 东海县| 洞头县| 治县。| 资中县| 中方县| 施秉县| 察雅县| 乌鲁木齐县| 勃利县| 寻甸| 莫力|