Re: compute_query_id and pg_stat_statements - Mailing list pgsql-hackers
From | Fujii Masao |
---|---|
Subject | Re: compute_query_id and pg_stat_statements |
Date | |
Msg-id | e3d3e3e5-0b33-5165-9121-6e770830e609@oss.nttdata.com Whole thread Raw |
In response to | Re: compute_query_id and pg_stat_statements (Julien Rouhaud <rjuju123@gmail.com>) |
Responses |
Re: compute_query_id and pg_stat_statements
Re: compute_query_id and pg_stat_statements |
List | pgsql-hackers |
On 2021/05/13 13:03, Julien Rouhaud wrote: > On Wed, May 12, 2021 at 11:33:32PM -0400, Bruce Momjian wrote: >> On Thu, May 13, 2021 at 11:16:13AM +0800, Julien Rouhaud wrote: >>> On Wed, May 12, 2021 at 11:06:52PM -0400, Bruce Momjian wrote: >>>> On Thu, May 13, 2021 at 09:57:00AM +0800, Julien Rouhaud wrote: >>>> >>>>> source? What if you have for instance pg_stat_statements, pg_stat_kcache, >>>>> pg_store_plans and pg_wait_sampling installed? All those extensions need a >>>>> query_id (or at least benefit from it for pg_wait_sampling), is there any value >>>>> to give a full list of all the modules that would enable compute_query_id? >>>> >>>> Well, we don't have any other cases where the source of the change is >>>> this indeterminate, so I don't really have a suggestion. I think this >>>> does highlight another case where 'auto' just isn't a good fit for our >>>> API. >>> >>> It may depends on your next question >>> >>>>> I'm assuming that anyone wanting to install any of those extensions (or any >>>>> similar one) is fully aware that they aggregate metrics based on at least a >>>>> query_id. If they don't, well they probably never read any documentation since >>>>> postgres 9.2 which introduced query normalization, and I doubt that they will >>>>> be interested in having access to the information anyway. >>>> >>>> My point is that we are changing a setting from an extension, and if you >>>> look in pg_setting, it will say "default"? >>> >>> No, it will say "on". What the patch I sent implements is: >> >> I was asking what pg_settings.source will say: >> >> SELECT name, soource FROM pg_settings; > > Oh sorry. Here's the full output before and after a dynamic call to > queryIsWanted(): > > name | compute_query_id > setting | auto > unit | <NULL> > category | Statistics / Monitoring > short_desc | Compute query identifiers. > extra_desc | <NULL> > context | superuser > vartype | enum > source | default > min_val | <NULL> > max_val | <NULL> > enumvals | {auto,on,off} > boot_val | auto > reset_val | auto > sourcefile | <NULL> > sourceline | <NULL> > pending_restart | f > > =# LOAD 'pg_qualstats'; /* will call queryIsWanted() */ > WARNING: 01000: Without shared_preload_libraries, only current backend stats will be available. > LOAD > > name | compute_query_id > setting | on > unit | <NULL> > category | Statistics / Monitoring > short_desc | Compute query identifiers. > extra_desc | <NULL> > context | superuser > vartype | enum > source | default > min_val | <NULL> > max_val | <NULL> > enumvals | {auto,on,off} > boot_val | auto > reset_val | auto > sourcefile | <NULL> > sourceline | <NULL> > pending_restart | f > > So yes, it says "default" (and it's the same if the change is done during > postmaster init). It can be fixed if that's the only issue. I like leaving compute_query_id=auto instead of overwriting it to "on", even when queryIsWanted() is called, as I told upthread. Then we can decide that query id computation is necessary when compute_query_id=auto and the special flag is enabled by queryIsWanted(). Of course as you and Magnus discussed upthread, the issue in EXEC_BACKEND case should be fixed, maybe by using save_backend_variables() or something, though. If we do this, compute_query_id=auto seems to be similar to huge_pages=try. When huge_pages=try, whether huge pages is actually used is defined depending outside PostgreSQL (i.e, OS setting in this case). Neither pg_settings.setting nor souce are not changed in that case. Regards, -- Fujii Masao Advanced Computing Technology Center Research and Development Headquarters NTT DATA CORPORATION
pgsql-hackers by date: