Re: shared-memory based stats collector - v69 - Mailing list pgsql-hackers
From | Andres Freund |
---|---|
Subject | Re: shared-memory based stats collector - v69 |
Date | |
Msg-id | 20220405231628.7urat2xerpb7iic2@alap3.anarazel.de Whole thread Raw |
In response to | Re: shared-memory based stats collector - v69 ("David G. Johnston" <david.g.johnston@gmail.com>) |
Responses |
Re: shared-memory based stats collector - v69
|
List | pgsql-hackers |
On 2022-04-05 14:43:49 -0700, David G. Johnston wrote: > On Tue, Apr 5, 2022 at 2:23 PM Andres Freund <andres@anarazel.de> wrote: > > > > > On 2022-04-05 13:51:12 -0700, David G. Johnston wrote: > > > > >, but rather add to the shared queue > > > > Queue? Maybe you mean the hashtable? > > > > Queue implemented by a list...? Anyway, I think I mean this: > /* > * List of PgStat_EntryRefs with unflushed pending stats. > * > * Newly pending entries should only ever be added to the end of the list, > * otherwise pgstat_flush_pending_entries() might not see them immediately. > */ > static dlist_head pgStatPending = DLIST_STATIC_INIT(pgStatPending); That's not in shared memory, but backend local... > > >, and so the cache is effectively read-only. It is also > > transaction-scoped > > >based upon the GUC and the nature of stats vis-a-vis transactions. > > > > No, that's not right. I think you might be thinking of > > pgStatLocal.snapshot.stats? > > > > > Probably... > > > > I guess I should add a paragraph about snapshots / fetch consistency. > > > > I apparently confused/combined the two concepts just now so that would help. Will add. > > > > > Even before I added the read-only and transaction-scoped I got a bit hung > > > up on reading: > > > "The shared hashtable only needs to be accessed when no prior reference > > to > > > the shared hashtable exists." > > > > > Thinking in terms of key seems to make more sense than value in this > > > sentence - even if there is a one-to-one correspondence. > > > > Maybe "prior reference to the shared hashtable exists for the key"? > > > > I specifically dislike having two mentions of the "shared hashtable" in the > same sentence, so I tried to phrase the second half in terms of the local > hashtable. You left two mentions of "shared hashtable" in the sentence prior though :). I'll try to rephrase. But it's not the end if this isn't the most elegant prose... > > Was that comma after e.g. intentional? > > > > It is. That is the style I was taught, and that we seem to adhere to in > user-facing documentation. Source code is a mixed bag with no enforcement, > but while we are here... Looks a bit odd to me. But I guess I'll add it then... > > > * > > > @@ -19,19 +19,21 @@ > > > * > > > * All variable-numbered stats are addressed by PgStat_HashKey while > > running. > > > * It is not possible to have statistics for an object that cannot be > > > - * addressed that way at runtime. A wider identifier can be used when > > > + * addressed that way at runtime. A alternate identifier can be used > > when > > > * serializing to disk (used for replication slot stats). > > > > Not sure this improves things. > > > > > It just seems odd that width is being mentioned when the actual struct is a > combination of three subcomponents. I do feel I'd need to understand > exactly what replication slot stats are doing uniquely here, though, to > make any point beyond that. There's no real numeric identifier for replication slot stats. So I'm using the "index" used in slot.c while running. But that can change during start/stop. Greetings, Andres Freund
pgsql-hackers by date: