On Mon, Dec 9, 2024 at 2:51 PM Masahiro Ikeda <ikeda...@oss.nttdata.com> wrote: > > On 2024-12-06 18:31, Bertrand Drouvot wrote: > > Hi, > > > > On Thu, Dec 05, 2024 at 10:43:51AM +0000, Bertrand Drouvot wrote: > >> Yeah, people would likely use this new field to monitor long running > >> vacuum. > >> Long enough that this error should be acceptable. Do you agree? > > > > OTOH, adding the 100% accuracy looks as simple as v9-0002 attached > > (0001 is > > same as for v8), so I think we should provide it. > This Idea looks good to me. Here are some comments
1. + Total amount of time spent in milliseconds waiting due to <xref linkend="guc-vacuum-cost-delay"/> + or <xref linkend="guc-autovacuum-vacuum-cost-delay"/>. In case of parallel + vacuum the reported time is across all the workers and the leader. The + workers update the column no more frequently than once per second, so it + could show slightly old values. + </para></entry> I think this waiting is influenced due to cost delay as well as cost limit GUCs because here we are counting total wait time and that very much depends upon how frequently we are waiting and that's completely driven by cost limit. Isn't it? 2. + if (IsParallelWorker()) + { + instr_time time_since_last_report; + + INSTR_TIME_SET_ZERO(time_since_last_report); + INSTR_TIME_ACCUM_DIFF(time_since_last_report, delay_end, + last_report_time); + nap_time_since_last_report += INSTR_TIME_GET_MILLISEC(delayed_time); + + if (INSTR_TIME_GET_MILLISEC(time_since_last_report) > WORKER_REPORT_DELAY_INTERVAL) + { + pgstat_progress_parallel_incr_param(PROGRESS_VACUUM_TIME_DELAYED, + nap_time_since_last_report); + nap_time_since_last_report = 0; + last_report_time = delay_end; + } + } Does it make sense to track this "nap_time_since_last_report" in a shared variable instead of local in individual workers and whenever the shared variable crosses WORKER_REPORT_DELAY_INTERVAL we can report this would avoid individual reporting from different workers. Since we are already computing the cost balance in shared variable i.e. VacuumSharedCostBalance, or do you think it will complicate the code? -- Regards, Dilip Kumar EnterpriseDB: http://www.enterprisedb.com