Re: Adding locks statistics
От | Michael Paquier |
---|---|
Тема | Re: Adding locks statistics |
Дата | |
Msg-id | aJqAei83uRWV93bM@paquier.xyz обсуждение исходный текст |
Ответ на | Re: Adding locks statistics (Jeff Davis <pgsql@j-davis.com>) |
Ответы |
Re: Adding locks statistics
Re: Adding locks statistics |
Список | pgsql-hackers |
On Mon, Aug 11, 2025 at 02:53:58PM -0700, Jeff Davis wrote: > On Mon, 2025-08-11 at 13:54 -0400, Greg Sabino Mullane wrote: > > Great idea. +1. Here is a quick overall review to get things started. > > Can you describe your use case? I'd like to understand whether this is > useful for users, hackers, or both. This is a DBA feature, so the questions I'd ask myself are basically: - Is there any decision-making where these numbers would help? These decisions would shape in tweaking the configuration of the server or the application to as we move from a "bad" number trend to a "good" number trend. - What would be good numbers? In this case, most likely a threshold reached over a certain period of time. - Would these new stats overlap with similar statistics gathered in the system, creating duplication and bloat in the pgstats for no real gain? Looking at the patch, the data gathered is this, and I don't think that we have metrics gathered in the system to get an idea of the contention in this area, for timeouts and deadlocks: + PgStat_Counter requests; + PgStat_Counter waits; + PgStat_Counter timeouts; + PgStat_Counter deadlock_timeouts; + PgStat_Counter deadlocks; + PgStat_Counter fastpath; Isn't the "deadlock_timeout" one an overlap between timeout and deadlock? Having three counters to track two concepts seems strange to me. Regarding the fastpath locking, you'd want to optimize the fastpath to be close to the number of requests. If you had these numbers, one thing that I could see a DBA do is tune max_locks_per_transaction, which is what influences the per-backend limit of fast-path locks, with FastPathLockGroupsPerBackend. Using static counters for the pending data is going to be necessary when these are called in critical sections, which is I guess why you've done it this way, right? -- Michael
Вложения
В списке pgsql-hackers по дате отправления: