1
0
mirror of https://github.com/postgres/postgres.git synced 2025-10-24 01:29:19 +03:00

Fix bug in LWLock statistics mechanism.

Previously PostgreSQL built with -DLWLOCK_STATS could report
more than one LWLock statistics entries for the same backend
process and the same LWLock. This is strange and only one
statistics should be output in that case, instead.

The cause of this issue is that the key variable used for
LWLock stats hash table was not fully initialized. The key
consists of two fields and they were initialized. But
the following 4 bytes allocated in the key variable for
the alignment was not initialized. So even if the same key
was specified, hash_search(HASH_ENTER) could not find
the existing entry for that key and created new one.

This commit fixes this issue by initializing the key
variable with zero. As the side effect of this commit,
the volume of LWLock statistics output would be reduced
very much.

Back-patch to v10, where commit 3761fe3c20 introduced the issue.

Author: Fujii Masao
Reviewed-by: Julien Rouhaud, Kyotaro Horiguchi
Discussion: https://postgr.es/m/26359edb-798a-568f-d93a-6aafac49752d@oss.nttdata.com
This commit is contained in:
Fujii Masao
2020-02-06 14:43:21 +09:00
parent 0e37489ed6
commit 3d214a8e5b

View File

@@ -310,6 +310,7 @@ get_lwlock_stats_entry(LWLock *lock)
return &lwlock_stats_dummy; return &lwlock_stats_dummy;
/* Fetch or create the entry. */ /* Fetch or create the entry. */
MemSet(&key, 0, sizeof(key));
key.tranche = lock->tranche; key.tranche = lock->tranche;
key.instance = lock; key.instance = lock;
lwstats = hash_search(lwlock_stats_htab, &key, HASH_ENTER, &found); lwstats = hash_search(lwlock_stats_htab, &key, HASH_ENTER, &found);