- 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.
In addition to those fundamental settings, there are a couple of new optimizer parameters to adjust the cost of parallel queries.
- 高性能混合信號ARM:ADuC7xxx原理與應用開發
- 輕松學Java
- Mastering Salesforce CRM Administration
- Maya極速引擎:材質篇
- 西門子S7-200 SMART PLC實例指導學與用
- Photoshop CS3圖像處理融會貫通
- Machine Learning with the Elastic Stack
- Mastering Geospatial Analysis with Python
- C++程序設計基礎(上)
- Mastering Exploratory Analysis with pandas
- Learning Apache Apex
- Learn QGIS
- 空間機器人智能感知技術
- 基于人工免疫原理的檢測系統模型及其應用
- ADuC系列ARM器件應用技術