| From: | Amit Kapila <amit(dot)kapila16(at)gmail(dot)com> |
|---|---|
| To: | Tom Lane <tgl(at)sss(dot)pgh(dot)pa(dot)us> |
| Cc: | Robert Haas <robertmhaas(at)gmail(dot)com>, jcnaylor(at)gmail(dot)com, pgsql-hackers <pgsql-hackers(at)postgresql(dot)org> |
| Subject: | Re: WIP: Avoid creation of the free space map for small tables |
| Date: | 2018-11-03 04:48:02 |
| Message-ID: | CAA4eK1KZzeH+W4s65ziSS-Tw4rqXnuQZ5bueJU9_8PnwQYnJpg@mail.gmail.com |
| Views: | Whole Thread | Raw Message | Download mbox | Resend email |
| Thread: | |
| Lists: | pgsql-hackers |
On Fri, Nov 2, 2018 at 7:37 PM Tom Lane <tgl(at)sss(dot)pgh(dot)pa(dot)us> wrote:
>
> Robert Haas <robertmhaas(at)gmail(dot)com> writes:
> > That's not what I'm saying. If we don't have the FSM, we have to
> > check every page of the table. If there's a workload where that
> > happens a lot on a table that is just under the size threshold for
> > creating the FSM, then it's likely to be a worst case for this patch.
>
> Hmm, you're assuming something not in evidence: why would that be the
> algorithm? On a FSM-less table, I'd be inclined to just check the
> last page and then grow the table if the tuple doesn't fit there.
> This would, in many cases, soon result in a FSM being created, but
> I think that's just fine. The point of the change is to optimize
> for cases where a table *never* gets more than a few inserts. Not, IMO,
> for cases where a table gets a lot of churn but never has a whole lot of
> live tuples. In the latter scenario we are far better off having a FSM.
>
In the past, you seem to have suggested an approach to try each block
[1] for small tables which don't have FSM. I think if we do what you
are suggesting now, then we don't need to worry much about any
regression and code will be somewhat simpler, but OTOH, I don't see
much harm in trying every block if we keep the threshold as no more
than 4. That would address more cases.
[1] - https://www.postgresql.org/message-id/11360.1345502641%40sss.pgh.pa.us
--
With Regards,
Amit Kapila.
EnterpriseDB: http://www.enterprisedb.com
| From | Date | Subject | |
|---|---|---|---|
| Next Message | Fabien COELHO | 2018-11-03 07:33:13 | Re: pgbench -M option can be specified more than once |
| Previous Message | Amit Kapila | 2018-11-03 04:41:28 | Re: WIP: Avoid creation of the free space map for small tables |