Re: ERROR: too many dynamic shared memory segments - Mailing list pgsql-hackers

From Tom Lane
Subject Re: ERROR: too many dynamic shared memory segments
Date
Msg-id 3647.1517601675@sss.pgh.pa.us
Whole thread Raw
Responses Re: ERROR: too many dynamic shared memory segments
List pgsql-hackers
Robert Haas <robertmhaas@gmail.com> writes:
> That turned out to produce more than one problem.  I find that the
> select_parallel test then fails like this:
> ERROR:  could not find key 18446744073709486082 in shm TOC at 0x10be98040
> The fix for that problem seems to be:

>      /* Recreate error queues. */
>      error_queue_space =
> -        shm_toc_lookup(pcxt->toc, PARALLEL_KEY_ERROR_QUEUE, false);
> +        shm_toc_lookup(pcxt->toc, PARALLEL_KEY_ERROR_QUEUE, true);
> +    Assert(pcxt->nworkers == 0 || error_queue_space != NULL);

I happened across this patch while preparing the release notes, and
I'm quite distressed by it, because it completely breaks the point
of what I'd done in commit d46633506 (to wit, to not just blindly
assume, nor just Assert, that shm_toc_lookup always succeeds).
Do you mind if I change that Assert to a run-time test?

            regards, tom lane


pgsql-hackers by date:

Previous
From: Simon Riggs
Date:
Subject: Re: [HACKERS] make async slave to wait for lsn to be replayed
Next
From: Robert Haas
Date:
Subject: Re: ERROR: too many dynamic shared memory segments