Type: | integer |
Défaut: | 0 |
Min: | 0 |
Max: | 1000000 |
Contexte: | sighup |
Redémarrer: | false |
Obsolète: | 15 |
Indique le nombre de transactions pour lesquelles VACUUM et les mises à jour HOT vont différer le nettoyage des versions de lignes mortes. La valeur par défaut est de 0 transactions. Cela signifie que les versions de lignes mortes peuvent être supprimées dès que possible, autrement dit dès qu'elles ne sont plus visibles par les transactions ouvertes. Vous pouvez configurer ce paramètre à une valeur supérieure à 0 sur un serveur primaire qui dispose de serveurs en Hot Standby comme décrit dans hot-standby. Ceci donne plus de temps aux requêtes des serveur en standby pour qu'elles se terminent sans engendrer de conflits dû à un nettoyage rapide des lignes. Néanmoins, comme la valeur correspond à un nombre de transactions en écriture survenant sur le serveur primaire, il est difficile de prédire le temps additionnel que cela donne aux requêtes exécutées sur le serveur en standby. Ce paramètre peut seulement être configuré dans le fichier postgresql.conf ou sur la ligne de commande du serveur.
Vous pouvez aussi configurer hot_standby_feedback sur les serveurs standby à la place de ce paramètre.
Ceci n'empêche pas le nettoyage des lignes mortes qui ont atteint l'âge spécifié par old_snapshot_threshold.
Recommandations [EN]
Sur StackOverflow
Sur pgsql-hackers
- Re: pgsql: Track last_inactive_time in pg_replication_slots.
- Re: BUG: Postgres 14 + vacuum_defer_cleanup_age + FOR UPDATE + UPDATE
- RE: Conflict detection for update_deleted in logical replication
- Re: Conflict detection for update_deleted in logical replication
- Re: Introduce XID age and inactive timeout based replication slot invalidation