| From: | Peter Geoghegan <pg(at)bowt(dot)ie> | 
|---|---|
| To: | Tom Lane <tgl(at)sss(dot)pgh(dot)pa(dot)us> | 
| Cc: | Heikki Linnakangas <hlinnaka(at)iki(dot)fi>, pgsql-hackers <pgsql-hackers(at)postgresql(dot)org>, Peter Geoghegan <pg(at)heroku(dot)com> | 
| Subject: | Re: Tuplesort merge pre-reading | 
| Date: | 2017-04-14 05:49:47 | 
| Message-ID: | CAH2-Wzm4e6XQcqLhLuszBQwEx=iq-MzE_Ve2SSLJYByOurC60g@mail.gmail.com | 
| Views: | Whole Thread | Raw Message | Download mbox | Resend email | 
| Thread: | |
| Lists: | pgsql-hackers | 
On Thu, Apr 13, 2017 at 10:19 PM, Peter Geoghegan <pg(at)bowt(dot)ie> wrote:
> I actually think Heikki's work here would particularly help on
> spinning rust, especially when less memory is available. He
> specifically justified it on the basis of it resulting in a more
> sequential read pattern, particularly when multiple passes are
> required.
BTW, what you might have missed is that Heikki did end up using a
significant amount of memory in the committed version. It just ended
up being managed by logtape.c, which now does the prereading instead
of tuplesort.c, but at a lower level. There is only one tuple in the
merge heap, but there is still up to 1GB of memory per tape,
containing raw preread tuples mixed with integers that demarcate tape
contents.
-- 
Peter Geoghegan
VMware vCenter Server
https://www.vmware.com/
| From | Date | Subject | |
|---|---|---|---|
| Next Message | Noah Misch | 2017-04-14 05:53:10 | Re: Allowing extended stats on foreign and partitioned tables | 
| Previous Message | Noah Misch | 2017-04-14 05:49:29 | Re: [pgsql-www] Small issue in online devel documentation build |