Distributed sort¶
Distributed sort allows to sort data which exceeds query.max-memory-per-node
.
Distributed sort is enabled via distributed_sort
session property or
distributed-sort
configuration property set in
etc/config.properties
of the coordinator. Distributed sort is enabled by
default.
When distributed sort is enabled, sort operator executes in parallel on multiple nodes in the cluster. Partially sorted data from each Presto worker node is then streamed to a single worker node for a final merge. This technique allows to utilize memory of multiple Presto worker nodes for sorting. The primary purpose of distributed sort is to allow for sorting of data sets which don’t normally fit into single node memory. Performance improvement can be expected, but it won’t scale linearly with the number of nodes since the data needs to be merged by a single node.