Re: Draft for basic NUMA observability - Mailing list pgsql-hackers
From | Bertrand Drouvot |
---|---|
Subject | Re: Draft for basic NUMA observability |
Date | |
Msg-id | Z9QcTi0yw4Z8tjGL@ip-10-97-1-34.eu-west-3.compute.internal Whole thread Raw |
In response to | Re: Draft for basic NUMA observability (Jakub Wartak <jakub.wartak@enterprisedb.com>) |
Responses |
Re: Draft for basic NUMA observability
|
List | pgsql-hackers |
Hi, On Fri, Mar 14, 2025 at 11:05:28AM +0100, Jakub Wartak wrote: > On Thu, Mar 13, 2025 at 3:15 PM Bertrand Drouvot > <bertranddrouvot.pg@gmail.com> wrote: > > Hi, > > Thank you very much for the review! I'm answering to both reviews in > one go and the results is attached v12, seems it all should be solved > now: Thanks for v12! I'll review 0001 and 0003 later, but want to share what I've done for 0002. I did prepare a patch file (attached as .txt to not disturb the cfbot) to apply on top of v11 0002 (I just rebased it a bit so that it now applies on top of v12 0002). The main changes are: === 1 Some doc wording changes. === 2 Some comments, pgindent and friends changes. === 3 relforknumber int2, relblocknumber int8, isdirty bool, usagecount int2, - pinning_backends int4, numa_zone_id int4); + pinning_backends int4, zone_id int4); I changed numa_zone_id to zone_id as we are already in "numa" related functions and/or views. === 4 - CHECK_FOR_INTERRUPTS(); } + + CHECK_FOR_INTERRUPTS(); I think that it's better to put the CFI outside of the if condition, so that it can be called for every page. === 5 -pg_buffercache_build_tuple(int i, BufferCachePagesContext *fctx) +pg_buffercache_build_tuple(int record_id, BufferCachePagesContext *fctx) for clarity. === 6 -get_buffercache_tuple(int i, BufferCachePagesContext *fctx) +get_buffercache_tuple(int record_id, BufferCachePagesContext *fctx) for clarity. === 7 - int os_page_count = 0; + uint64 os_page_count = 0; I think that's better. === 8 But then, here, we need to change its format to %lu and and to cast to (unsigned long) to make the CI CompilerWarnings happy. That's fine because we don't provide NUMA support for 32 bits anyway. - elog(DEBUG1, "NUMA: os_page_count=%d os_page_size=%zu pages_per_blk=%f", - os_page_count, os_page_size, pages_per_blk); + elog(DEBUG1, "NUMA: os_page_count=%lu os_page_size=%zu pages_per_blk=%.2f", + (unsigned long) os_page_count, os_page_size, pages_per_blk); === 9 -static bool firstUseInBackend = true; +static bool firstNumaTouch = true; Looks better to me but still not 100% convinced by the name. === 10 static BufferCachePagesContext * -pg_buffercache_init_entries(FuncCallContext *funcctx, PG_FUNCTION_ARGS) +pg_buffercache_init_entries(FuncCallContext *funcctx, FunctionCallInfo fcinfo) as PG_FUNCTION_ARGS is usually used for fmgr-compatible function and there is a lof of examples in the code that make use of "FunctionCallInfo" for non fmgr-compatible function. and also: === 11 I don't like the fact that we iterate 2 times over NBuffers in pg_buffercache_numa_pages(). But I'm having having hard time finding a better approach given the fact that pg_numa_query_pages() needs all the pointers "prepared" before it can be called... Those 2 loops are probably the best approach, unless someone has a better idea. === 12 Upthread you asked "Can you please take a look again on this, is this up to the project standards?" Was the question about using pg_buffercache_numa_prepare_ptrs() as an inlined wrapper? What do you think? The comments, doc and code changes are just proposals and are fully open to discussion. Regards, -- Bertrand Drouvot PostgreSQL Contributors Team RDS Open Source Databases Amazon Web Services: https://aws.amazon.com
Attachment
pgsql-hackers by date: