pg_stat_activity
pg_stat_replication
pg_stat_wal_receiver
pg_stat_subscription
pg_stat_ssl
pg_stat_gssapi
pg_stat_archiver
pg_stat_bgwriter
pg_stat_database
pg_stat_database_conflicts
pg_stat_all_tables
pg_stat_all_indexes
pg_statio_all_tables
pg_statio_all_indexes
pg_statio_all_sequences
pg_stat_user_functions
pg_stat_slru
Le récupérateur de statistiques de PostgreSQL est un sous-système qui prend en charge la récupération et les rapports d'informations sur l'activité du serveur. Actuellement, le récupérateur peut compter les accès aux tables et index à la fois en termes de blocs disque et de lignes individuelles. Il conserve aussi la trace du nombre total de lignes dans chaque table ainsi que des informations sur les VACUUM et les ANALYZE pour chaque table. Il peut aussi compter le nombre d'appels aux fonctions définies par l'utilisateur ainsi que le temps total dépensé par chacune d'elles.
PostgreSQL est également capable de renvoyer des informations dynamiques en temps réel sur ce qu'il se passe exactement dans le système, comme la commande exacte en cours d'exécution par d'autres processus serveur et les autres connexions qui existent dans le système. Cette fonctionnalité est indépendante du processus de récupération de données statistiques.
Comme la récupération de statistiques ajoute un temps supplémentaire à
l'exécution de la requête, le système peut être configuré pour récupérer ou
non des informations. Ceci est contrôlé par les paramètres de configuration
qui sont normalement initialisés dans postgresql.conf
(voir
Chapitre 19 pour plus de détails sur leur
initialisation).
Le paramètre track_activities active la collecte d'informations sur la commande en cours d'exécution pour n'importe quel processus serveur.
Le paramètre track_counts contrôle si les statistiques sont récupérées pour les accès aux tables et index.
Le paramètre track_functions active le calcul de statistiques sur l'utilisation des fonctions définies par l'utilisateur.
Le paramètre track_io_timing active la collecte des temps de lecture et d'écriture de blocs.
Normalement, ces paramètres sont configurés dans
postgresql.conf
de façon à ce qu'ils s'appliquent à tous les
processus serveur, mais il est possible de les activer/désactiver sur des
sessions individuelles en utilisant la commande SET (pour empêcher les utilisateurs
ordinaires de cacher leur activité à l'administrateur, seuls les
superutilisateurs sont autorisés à modifier ces paramètres avec
SET
).
Le collecteur de statistiques transmet l'information récupérée
aux autres processus PostgreSQL à travers
des fichiers temporaires. Ces fichiers sont stockés dans le répertoire
défini par le paramètre stats_temp_directory,
par défaut pg_stat_tmp
.
Pour de meilleures performances, stats_temp_directory
peut pointer vers un disque en RAM, diminuant ainsi les besoins en
entrées/sorties physiques. Quand le serveur s'arrête proprement, une copie
permanente des données statistiques est stockée dans le sous-répertoire
pg_stat
, pour que les statistiques puissent être
conservées puis réutilisées au redémarrage du serveur. Lorsqu'au démarrage du
serveur, la restauration est réalisée (par exemple, après un arrêt
immédiat, un crash du serveur ou encore après une restauration PITR), tous
les compteurs statistiques sont réinitialisés.
Une transaction peut aussi voir des statistiques propres à son
activité (qui ne sont pas encore transmises au collecteur) dans les
vues pg_stat_xact_all_tables
,
pg_stat_xact_sys_tables
,
pg_stat_xact_user_tables
et
pg_stat_xact_user_functions
.
Ces informations se mettent à jour
en continu pendant l'exécution de la transaction.
Plusieurs vues prédéfinies, listées à Tableau 27.1, sont disponibles pour montrer l'état courant du système. Il existe aussi plusieurs autres vues, listées à Tableau 27.2, qui montrent les résultats des statistiques récupérées. De manière alternative, il est possible de créer des vues personnalisées qui utilisent les fonctions statistiques sous-jacentes, comme discuté à Section 27.2.20.
En utilisant les statistiques pour surveiller l'activité en cours, il est
important de réaliser que l'information n'est pas mise à jour instantanément.
Chaque processus serveur individuel transmet les nouvelles statistiques au
récupérateur juste avant l'attente d'une
nouvelle commande du client ; donc une requête toujours en cours
n'affecte pas les totaux affichés. De plus, le récupérateur lui-même émet un
nouveau rapport une fois par PGSTAT_STAT_INTERVAL
millisecondes (soit 500 millisecondes, sauf si cette valeur a été modifiée lors de la
construction du serveur). Donc, les totaux affichés sont bien derrière
l'activité réelle. Néanmoins, l'information sur la requête en cours récupérée
par track_activities
est toujours à jour.
Un autre point important est que, lorsqu'un processus serveur se voit
demander d'afficher une des statistiques, il récupère tout d'abord le rapport
le plus récent émis par le processus de récupération, puis continue
d'utiliser cette image de toutes les vues et fonctions statistiques jusqu'à
la fin de sa transaction en cours. De façon similaire, les informations sur
les requêtes en cours, quel que soit le processus, sont récupérées quand une
telle information est demandée dans une transaction, et cette même information
sera affichée lors de la transaction. Donc, les statistiques afficheront des
informations statiques tant que vous restez dans la même transaction. Ceci est une
fonctionnalité, et non pas un bogue, car il vous permet de traiter plusieurs
requêtes sur les statistiques et de corréler les résultats sans vous
inquiéter que les nombres aient pu changer. Mais si vous voulez voir les
nouveaux résultats pour chaque requête, assurez-vous de lancer les requêtes
en dehors de tout bloc de transaction. Autrement, vous pouvez appeler
pg_stat_clear_snapshot
(), qui annulera l'image statistique
de la transaction en cours. L'utilisation suivante des informations
statistiques causera la récupération d'une nouvelle image.
Certaines des informations des vues statistiques dynamiques montrées dans
Tableau 27.1 sont à accès
restreint. Les utilisateurs ordinaires peuvent seulement voir toutes les
informations sur leur propres sessions (les sessions appartenant à un rôle
dont ils sont membres). Les lignes des autres sessions auront de nombreuses
colonnes à NULL. Notez néanmoins que l'existence d'une session et ses
propriétés générales, tel que l'utilisateur et la base de données, sont
visibles à tous les utilisateurs. Les superutilisateurs et les membres du
rôle interne pg_read_all_stats
(voir aussi Section 21.5) peuvent accéder à toutes les informations sur
les sessions.
Tableau 27.1. Vues statistiques dynamiques
Nom de la vue | Description |
---|---|
pg_stat_activity
|
Une ligne par processus serveur, montrant les informations
liées à l'activité courante du processus, comme l'état et la
requête en cours. Voir
pg_stat_activity
pour plus de détails.
|
pg_stat_replication | Une ligne par processus d'envoi de WAL, montrant les
statistiques sur la réplication vers le serveur standby connecté
au processus.
Voir
pg_stat_replication pour les détails.
|
pg_stat_wal_receiver | Seulement une ligne, affichant des statistiques sur le récepteur
WAL à partir du serveur ayant ce récepteur. Voir
pg_stat_wal_receiver pour les détails.
|
pg_stat_subscription | Au moins une ligne par souscription, affichant des informations
sur les processus workers de souscription. Voir
pg_stat_subscription pour plus de détails.
|
pg_stat_ssl | Une ligne par connexion (régulière et de réplication),
montrant des informations sur le chiffrement SSL utilisé pour
ces connexions.
Voir
pg_stat_ssl pour les détails.
|
pg_stat_gssapi | Une ligne par connexion (standard et réplication), montrant des
informations sur l'authentification et le chiffrement GSSAPI utilisés
sur cette connexion. Voir
pg_stat_gssapi pour
les détails.
|
pg_stat_progress_analyze | Une ligne pour chaque connexion (incluant celles des processus
autovacuum worker) exécutant un
ANALYZE , pour indiquer le progrès actuel.
Voir Section 27.4.1.
|
pg_stat_progress_create_index | Une ligne pour chaque processus serveur exécutant un CREATE
INDEX ou un REINDEX , affichant la
progression actuelle. Voir
Section 27.4.2.
|
pg_stat_progress_vacuum | Une ligne pour chaque processus (incluant les processus
autovacuum worker) exécutant un VACUUM , affichant le
progrès en cours. Voir Section 27.4.3. |
pg_stat_progress_cluster | Une ligne pour chaque processus serveur exécutant
CLUSTER ou VACUUM FULL , affichant
le progrès en cours.
Voir Section 27.4.4.
|
pg_stat_progress_basebackup | Une ligne pour chaque processus walsender envoyant une sauvegarde de base, en affichant le progrès actuel. Voir Section 27.4.5. |
Tableau 27.2. Vues sur les statistiques récupérées
Nom de la vue | Description |
---|---|
pg_stat_archiver | Une seule ligne, montrant les statistiques sur l'activité du
processus d'archivage des journaux de transactions. Voir
pg_stat_archiver pour les détails.
|
pg_stat_bgwriter | Une seule ligne, montrant les statistiques
d'activité du processus d'écriture d'arrière-plan.
Voir
pg_stat_bgwriter pour plus de détails.
|
pg_stat_database | Une ligne par base de données, montrant les statistiques
globales des bases. Voir
pg_stat_database
pour plus de détails.
|
pg_stat_database_conflicts |
Une ligne par base de données, montrant les statistiques au
niveau de la base concernant les requêtes annulées à cause de
conflits avec les serveurs standby en restauration.
Voir
pg_stat_database_conflicts pour les détails.
|
pg_stat_all_tables |
Une ligne par table de la base de données courante, montrant les
statistiques d'accès de chaque table spécifiquement. Voir
pg_stat_all_tables pour plus de détails.
|
pg_stat_sys_tables | Identique à pg_stat_all_tables , sauf que seules les
tables systèmes sont affichées |
pg_stat_user_tables | Identique à pg_stat_all_tables , sauf que seules les
tables utilisateurs sont affichées |
pg_stat_xact_all_tables | Similaire à pg_stat_all_tables , mais
décompte les actions prises dans la transaction en cours (qui ne
sont pas encore pris en compte dans la vue
pg_stat_all_tables et les vues du même
type). Les colonnes correspondant au nombre de lignes vivantes et
mortes, ainsi que celles pour les actions du VACUUM et de l'ANALYZE
ne sont pas présentes dans cette vue |
pg_stat_xact_sys_tables | Identique à pg_stat_xact_all_tables ,
sauf que seules les tables systèmes sont affichées |
pg_stat_xact_user_tables | Identique à pg_stat_xact_all_tables , sauf que seules les
tables utilisateurs sont affichées |
pg_stat_all_indexes |
Une ligne par index de la base de données courante, montrant les
statistiques d'accès de chaque index spécifiquement. Voir
pg_stat_all_indexes pour plus de détails.
|
pg_stat_sys_indexes | Identique à pg_stat_all_indexes , sauf que seules les
tables systèmes sont affichées |
pg_stat_user_indexes | Identique à pg_stat_all_indexes , sauf que seules
les tables utilisateurs sont affichées |
pg_statio_all_tables |
Une ligne par table de la base de données courante, montrant les
statistiques d'entrées/sorties de chaque table spécifiquement. Voir
pg_statio_all_tables pour plus de détails.
|
pg_statio_sys_tables | Identique à pg_statio_all_tables , sauf que seules
les tables systèmes sont affichées |
pg_statio_user_tables | Identique à pg_statio_all_tables , sauf que seules
les tables utilisateur sont affichées |
pg_statio_all_indexes |
Une ligne par index de la base de données courante, montrant les
les statistiques d'entrées/sorties de chaque index spécifiquement. Voir
pg_statio_all_indexes pour plus de détails.
|
pg_statio_sys_indexes | Identique à pg_statio_all_indexes , sauf que seuls
les index systèmes sont affichés |
pg_statio_user_indexes | Identique à pg_statio_all_indexes , sauf que seuls
les index utilisateur sont affichés |
pg_statio_all_sequences |
Une ligne par séquence de la base de données courante, montrant les
statistiques d'entrées/sorties de chaque séquence spécifiquement. Voir
pg_statio_all_sequences pour plus de détails.
|
pg_statio_sys_sequences | Identique à pg_statio_all_sequences , sauf que
seules les séquences système sont affichées (actuellement, aucune
séquence système n'est définie, donc cette vue est toujours vide) |
pg_statio_user_sequences | Identique à pg_statio_all_sequences , sauf que
seules les séquences utilisateur sont affichées |
pg_stat_user_functions |
Une ligne par fonction suivie, montrant les statistiques
d'exécution de cette fonction. Voir
pg_stat_user_functions pour plus de détails.
|
pg_stat_xact_user_functions | Similaire à pg_stat_user_functions ,
mais compte seulement les appels pendant la transaction en cours
(qui ne sont pas encore inclus dans
pg_stat_user_functions ) |
pg_stat_slru | Une ligne par SLRU, affichant les statistiques des opérations.
Voir
pg_stat_slru pour les détails.
|
Les statistiques par index sont particulièrement utiles pour déterminer les index utilisés et leur efficacité.
Les vues pg_statio_
sont principalement utiles pour
déterminer l'efficacité du cache tampon. Quand le nombre de lectures disques
réelles est plus petit que le nombre de récupérations valides par le tampon,
alors le cache satisfait la plupart des demandes de lecture sans faire appel
au noyau. Néanmoins, ces statistiques ne nous donnent pas l'histoire
complète : à cause de la façon dont PostgreSQL gère les
entrées/sorties disque, les données qui ne sont pas dans le tampon de
PostgreSQL pourraient toujours résider dans le tampon
d'entrées/sorties du noyau et pourraient, du coup, être toujours récupérées
sans nécessiter une lecture physique. Les utilisateurs intéressés pour
obtenir des informations plus détaillées sur le comportement des
entrées/sorties dans PostgreSQL sont invités à utiliser le
récupérateur de statistiques de PostgreSQL avec les outils du
système d'exploitation permettant une vue de la gestion des
entrées/sorties par le noyau.
pg_stat_activity
La vue pg_stat_activity
aura une ligne par
processus serveur, montrant des informations liées à l'activité courante de
ce processus.
Tableau 27.3. Vue pg_stat_activity
Type Description |
---|
OID de la base de données auquel ce processus serveur est connecté |
Nom de la base de données auquel ce processus serveur est connecté |
Identifiant du processus serveur |
Identifiant du processus du leader pour une requête parallélisée si ce
si ce processus est un worker. |
OID de l'utilisateur connecté à ce processus serveur |
Nom de l'utilisateur connecté à ce processus serveur |
Nom de l'application connectée à ce processus serveur |
Adresse IP du client pour ce processus serveur. Si ce champ est vide, cela indique soit que le client est connecté via un socket Unix sur la machine serveur soit qu'il s'agit d'un processus interne tel qu'autovacuum. |
Nom d'hôte du client connecté, comme reporté par une recherche DNS
inverse sur |
Numéro de port TCP que le client utilise pour communiquer
avec le processus serveur,
ou |
Heure de démarrage du processus. Pour les processus backends, c'est l'heure où le client s'est connecté au serveur. |
Heure de démarrage de la transaction courante du
processus, ou NULL si aucune transaction n'est active. Si la
requête courante est la première de sa transaction, cette
colonne a la même valeur que la colonne
|
Heure à laquelle la requête active a été démarrée, ou
si |
Heure à laquelle l'état ( |
Type de l'événement pour lequel le processus est en attente sinon NULL. Voir Tableau 27.4. |
Nom de l'événement d'attente si le processus est en attente, NULL dans le cas contraire. Voir Tableau 27.5 jusqu'à Tableau 27.13. |
État général du processus serveur. Les valeurs possibles sont :
|
Identifiant de transaction de haut niveau de ce processus, si disponible. |
L'horizon |
Texte de la requête la plus récente pour ce processus serveur. Si
|
Type du processus actuel. Les types possibles sont
|
Les colonnes wait_event
et
state
sont indépendantes. Si un processus
serveur est dans l'état active
, il pourrait, ou non,
être en attente (waiting
) d'un événement. Si l'état est
active
et si wait_event
est
différent de NULL, cela signifie qu'une requête est en cours d'exécution,
mais que cette exécution est bloquée quelque part dans le système.
Tableau 27.4. Types de Wait Event
Type de Wait Event | Description |
---|---|
Activity |
Le processus serveur est en attente. Ce type d'événement indique un
processus attendant une activité dans sa boucle de traitement
principal. wait_event identifie le point d'attente
spécifique ; voir Tableau 27.5.
|
BufferPin | Le processus serveur est en attente d'un accès exclusif à un tampon de données. Les attentes de ce type peuvent être prolongées si un autre processus détient un curseur ouvert qui a lu des données du tampon en question. Voir Tableau 27.6. |
Client | Le processus serveur est en attente d'activité sur un socket
connecté à une application utilisateur. De ce fait, le serveur s'attend
à une action indépendante de ses processus internes.
wait_event identifie le point d'attente
spécifique ; voir Tableau 27.7.
|
Extension | Le processus serveur est en attente d'une condition définie par une extension. Voir Tableau 27.8. |
IO | Le processus serveur est en attente de la fin d'une opération I/O.
wait_event identifie le point d'attente
spécifique ; voir Tableau 27.9.
|
IPC | Le processus serveur est en attente d'une interaction avec un
autre processus serveur. wait_event identifie le
point d'attente spécifique ; voir Tableau 27.10.
|
Lock | Le processus serveur est un attente d'un verrou lourd. Les verrous
lourds, aussi connus sous le nom de verrous du gestionnaire ou
simplement verrous, protègent principalement les objets SQL comme les
tables. Néanmoins, ils sont aussi utilisés pour assurer l'exclusion
mutuelle pour certaines opérations internes comme l'agrandissement
d'une relation. wait_event identifie le type de
verrou en attente ; voir Tableau 27.11.
|
LWLock | Le processus serveur est en attente d'un verrou léger. La plupart
de ces types de verrou protègent une structure de données spécifique en
mémoire partagée. wait_event contient un nom
identifiant le but de ce verrou léger. (Certains verrous ont des noms
spécifiques ; les autres font partie d'un groupe de verrous,
chacun ayant le même but.) Voir Tableau 27.12.
|
Timeout | Le processus serveur est en attente de l'expiration d'un délai.
wait_event identifie le point d'attente
spécifique ; voir Tableau 27.13.
|
Tableau 27.5. Wait Events de type Activity
Wait Event Activity | Description |
---|---|
ArchiverMain | En attente dans la boucle principale du processus archiver. |
AutoVacuumMain | En attente dans la boucle principale du processus autovacuum launcher. |
BgWriterHibernate | En attente du processus background writer, en hibernation. |
BgWriterMain | En attente dans la boucle principale du processus background writer. |
CheckpointerMain | En attente dans la boucle principale du processus checkpointer. |
LogicalApplyMain | En attente dans la boucle principale du processus logical replication apply. |
LogicalLauncherMain | En attente dans la boucle principale du processus logical replication launcher. |
PgStatMain | En attente dans la boucle principale du processus statistics collector. |
RecoveryWalStream | En attente dans la boucle principale du processus startup pour l'arrivée des WAL durant la réplication en flux. |
SysLoggerMain | En attente dans la boucle principale du processus syslogger. |
WalReceiverMain | En attente dans la boucle principale du processus WAL receiver. |
WalSenderMain | En attente dans la boucle principale du processus WAL sender. |
WalWriterMain | En attente dans la boucle principale du processus WAL writer. |
Tableau 27.6. Wait Events de type BufferPin
Wait Event BufferPin | Description |
---|---|
BufferPin | En attente de l'acquisition d'un verrou exclusif sur un tampon. |
Tableau 27.7. Wait Events de type Client
Wait Event Client | Description |
---|---|
ClientRead | En attente d'une lecture de données provenant du client. |
ClientWrite | En attente d'écriture de données vers le client. |
GSSOpenServer | En attente de lecture de données provenant du client lors de l'établissement d'une session GSSAPI. |
LibPQWalReceiverConnect | En attente de WAL receiver pour établir une connexion vers un serveur distant. |
LibPQWalReceiverReceive | En attente de WAL receiver pour recevoir des données provenant d'un serveur distant. |
SSLOpenServer | En attente de SSL lors d'une tentative de connexion. |
WalReceiverWaitStart | En attente du processus startup pour l'envoi des données initiales pour une réplication en flux. |
WalSenderWaitForWAL | En attente de l'envoi des WAL au processus WAL sender. |
WalSenderWriteData | En attente de toute activité pendant le traitement des réponses provenant du WAL receiver dans le processus WAL sender. |
Tableau 27.8. Wait Events de type Extension
Wait Event Extension | Description |
---|---|
Extension | En attente d'une extension. |
Tableau 27.9. Wait Events de type IO
Wait Event IO | Description |
---|---|
BufFileRead | En attente d'une lecture d'un fichier en cache. |
BufFileWrite | En attente d'une écriture dans un fichier en cache. |
ControlFileRead | En attente d'une lecture à partir du fichier
pg_control . |
ControlFileSync | En attente que le fichier pg_control atteigne
un stockage stable. |
ControlFileSyncUpdate | En attente qu'une mise à jour du fichier
pg_control atteigne un stockage stable. |
ControlFileWrite | En attente d'une écriture dans le fichier
pg_control . |
ControlFileWriteUpdate | En attente d'une écriture pour mettre à jour le fichier
pg_control . |
CopyFileRead | En attente d'une lecture lors d'une opération de copie de fichier. |
CopyFileWrite | En attente d'une écriture lors d'une opération de copie de fichier. |
DSMFillZeroWrite | En attente du remplissage d'un fichier de mémoire partagée dynamique avec des zéros. |
DataFileExtend | En attente de l'agrandissement d'un fichier de données. |
DataFileFlush | En attente que le fichier de données atteigne un stockage stable. |
DataFileImmediateSync | En attente d'une synchronisation immédiate d'un fichier de données vers un stockage stable. |
DataFilePrefetch | En attente d'une prélecture asynchrone à partir d'un fichier de données. |
DataFileRead | En attente d'une lecture à partir d'un fichier de données. |
DataFileSync | En attente de modifications dans un fichier de données pour atteindre un stockage stable. |
DataFileTruncate | En attente de la troncature d'un fichier de données. |
DataFileWrite | En attente de l'écriture d'un fichier de données. |
LockFileAddToDataDirRead | En attente d'une lecture lors de l'ajout d'une ligne dans le fichier de verrouillage du répertoire des données. |
LockFileAddToDataDirSync | En attente que les données atteignent un stockage stable lors de l'ajout d'une ligne dans le fichier de verrouillage du répertoire des données. |
LockFileAddToDataDirWrite | En attente d'une écriture lors de l'ajout d'une ligne dans le fichier de verrouillage du répertoire des données. |
LockFileCreateRead | En attente d'une lecture lors de la création du fichier de verrouillage du répertoire des données. |
LockFileCreateSync | En attente des données pour atteindre un stockage stable lors de la création du fichier de verrouillage du répertoire des données. |
LockFileCreateWrite | En attente d'une écriture lors de la création du fichier de verrouillage du répertoire des données. |
LockFileReCheckDataDirRead | En attente d'une lecture lors de la vérification du fichier de verrouillage du répertoire des données. |
LogicalRewriteCheckpointSync | En attente que les correspondances de réécriture logique atteignent un stockage stable lors d'un checkpoint. |
LogicalRewriteMappingSync | En attente que les données de correspondance atteignent un stockage stable lors d'une réécriture logique. |
LogicalRewriteMappingWrite | En attente d'une écriture des données de correspondance lors d'une réécriture logique. |
LogicalRewriteSync | En attente que les correspondances de réécriture logique atteignent un stockage stable. |
LogicalRewriteTruncate | En attente de la troncature de données de correspondance lors d'une réécriture logique. |
LogicalRewriteWrite | En attente d'une écriture des correspondances de réécriture logique. |
RelationMapRead | En attente d'une lecture du fichier de carte des relations. |
RelationMapSync | En attente que le fichier de carte des relations atteigne un stockage stable. |
RelationMapWrite | En attente d'une écriture dans le fichier de carte des relations. |
ReorderBufferRead | En attente d'une lecture lors de la gestion des tampons réordonnés. |
ReorderBufferWrite | En attente d'une écriture lors de la gestion des tampons réordonnés. |
ReorderLogicalMappingRead | En attente d'une lecture d'une correspondance logique lors de la gestion des tampons réordonnés. |
ReplicationSlotRead | En attente d'une lecture d'un fichier de contrôle d'un slot de réplication. |
ReplicationSlotRestoreSync | En attente que le fichier de contrôle du slot de réplication atteigne un stockage stable pour le restaurer en mémoire. |
ReplicationSlotSync | En attente que le fichier de contrôle du slot de réplication atteigne un stockage stable. |
ReplicationSlotWrite | En attente de l'écriture d'un fichier de contrôle du slot de réplication. |
SLRUFlushSync | En attente que les données SLRU atteignent un stockage stable lors d'un checkpoint ou d'un arrêt de base. |
SLRURead | En attente d'une lecture d'une page SLRU. |
SLRUSync | En attente que les données SLRU atteignent un stockage stable suivant l'écriture d'une page. |
SLRUWrite | En attente d'une écriture d'une page SLRU. |
SnapbuildRead | En attente d'une lecture d'une image d'un catalogue historique sérialisé. |
SnapbuildSync | En attente qu'une image d'un catalogue historique sérialisé atteigne un stockage stable. |
SnapbuildWrite | En attente d'une écriture d'une image d'un catalogue historique sérialisé. |
TimelineHistoryFileSync | En attente qu'un fichier d'historique des timelines soit reçu via la réplication en flux pour atteindre un stockage stable. |
TimelineHistoryFileWrite | En attente de l'écriture d'un fichier d'historique des timelines reçu via la réplication en flux. |
TimelineHistoryRead | En attente de la lecture d'un fichier d'historique des timelines. |
TimelineHistorySync | En attente qu'un fichier d'historique des timelines nouvellement créé atteigne un stockage stable. |
TimelineHistoryWrite | En attente de l'écriture d'un fichier d'historique des timelines nouvellement créé. |
TwophaseFileRead | En attente de la lecture d'un fichier d'état pour le 2PC. |
TwophaseFileSync | En attente que le fichier d'état pour le 2PC atteigne un stockage stable. |
TwophaseFileWrite | En attente d'une écriture un fichier d'état pour le 2PC. |
WALBootstrapSync | En attente que le WAL atteigne un stockage stable lors du bootstrapping. |
WALBootstrapWrite | En attente d'un écriture d'une page WAL lors du bootstrapping. |
WALCopyRead | En attente d'une lecture lors de la création d'un nouveau segment WAL en copiant un WAL existant. |
WALCopySync | En attente d'un nouveau segment WAL copié un WAL existant pour atteindre un stockage stable. |
WALCopyWrite | En attente d'une écriture lors de la création d'un nouveau segment WAL en en copiant un existant. |
WALInitSync | En attente que le fichier WAL nouvellement initialisé atteigne un stockage stable. |
WALInitWrite | En attente d'une écriture lors de l'initialisation d'un nouveau fichier WAL. |
WALRead | En attente d'une lecture à partir d'un fichier WAL. |
WALSenderTimelineHistoryRead | En attente d'une lecture à partir d'un fichier d'historique des timelines lors qu'une commande de timeline d'un walsender. |
WALSync | En attente qu'un fichier WAL atteigne un stockage stable. |
WALSyncMethodAssign | En attente que les données atteignent un stockage stable lors de l'affectation d'une nouvelle méthode de synchronisation des WAL. |
WALWrite | En attente d'une écriture dans un fichier WAL. |
Tableau 27.10. Wait Events de type IPC
Wait Event IPC | Description |
---|---|
BackupWaitWalArchive | En attente que les fichiers WAL requis pour une sauvegarde soient correctement archivés. |
BgWorkerShutdown | En attente de l'arrêt du background worker. |
BgWorkerStartup | En attente du démarrage du background worker. |
BtreePage | En attente que le numéro de page requis pour continuer un parcours parallélisé d'un index B-tree soit disponible. |
CheckpointDone | En attente de la fin d'un checkpoint. |
CheckpointStart | En attente du démarrage d'un checkpoint. |
ExecuteGather | En attente de l'activité d'un processus fils lors de l'exécution
du nœud Gather . |
HashBatchAllocate | En attente qu'un participant d'un Parallel Hash alloue une table de hachage. |
HashBatchElect | En attente de l'élection d'un participant d'un Parallel Hash pour allouer une table de hachage. |
HashBatchLoad | En attente que les autres participants d'un Parallel Hash finissent de charger une table de hachage. |
HashBuildAllocate | En attente qu'un participant élu d'un Parallel Hash alloue la table de hachage initiale. |
HashBuildElect | En attente de l'élection d'un participant à un Parallel Hash pour allouer la table de hachage. |
HashBuildHashInner | En attente que les autres participants à un Parallel Hash finissent le hachage de la relation interne. |
HashBuildHashOuter | En attente que les autres participants à un Parallel Hash finissent le partitionnement de la relation externe. |
RegisterSyncRequest | Attente lors de l'envoi des demandes de synchronisation au checkpointer car la queue de demandes est remplie. |
HashGrowBatchesAllocate | En attente qu'un participant élu à un Parallel Hash alloue plus de batches. |
HashGrowBatchesDecide | En attente de l'élection d'un participant à un Parallel Hash pour décider de l'agrandissement futur du batch. |
HashGrowBatchesElect | En attente de l'élection d'un participant à un Parallel Hash pour participer à l'allocation d'un plus grand nombre de batches. |
HashGrowBatchesFinish | En attente de l'élection d'un participant à un Parallel Hash pour décider de l'agrandissement futur du batch. |
HashGrowBatchesRepartition | En attente que les autres participants d'un Parallel Hash terminent le repartitionement. |
HashGrowBucketsAllocate | En attente qu'un participant élu à un Parallel Hash fissent l'allocation d'un plus grand nombre de buckets. |
HashGrowBucketsElect | En attente de l'élection d'un participant à un Parallel Hash pour allouer plus de buckets. |
HashGrowBucketsReinsert | En attente que les autres participants d'un Parallel Hash finissent d'insérer des lignes dans les nouveaux buckets. |
LogicalSyncData | En attente qu'un serveur distant de réplication logique envoie les données pour la synchronisation initiale de la table. |
LogicalSyncStateChange | En attente qu'un serveur distant de réplication logique change l'état. |
MessageQueueInternal | En attente qu'un autre processus soit attaché à une queue de messages partagé. |
MessageQueuePutMessage | En attente de l'écriture d'un message de protocole dans une queue de messages partagé. |
MessageQueueReceive | En attente de la réception d'octets à partir d'une queue de messages partagé. |
MessageQueueSend | En attente de l'envoi d'octets vers une queue de messages partagé. |
ParallelBitmapScan | En attente que le parcours parallélisé de bitmap soit initialisé. |
ParallelCreateIndexScan | En attente que les workers parallélisés d'un CREATE INDEX
finissent le parcours de la table. |
ParallelFinish | En attente que les workers parallélisés finissent le traitement. |
ProcArrayGroupUpdate | En attente que le leader du groupe efface l'identifiant de transaction à la fin d'une opération parallélisée. |
ProcSignalBarrier | En attente qu'un événement barrier soit traité par tous les processus serveurs. |
Promote | En attente de la promotion du standby. |
RecoveryConflictSnapshot | En attente de la résolution du conflit de restauration pour un nettoyage par VACUUM. |
RecoveryConflictTablespace | En attente de la résolution du conflit de restauration suite à la suppression d'un tablespace. |
RecoveryPause | En attente de la remise en route de la restauration. |
ReplicationOriginDrop | En attente que l'origine de réplication devienne inactive, pour qu'elle puisse être supprimée. |
ReplicationSlotDrop | En attente que le slot de réplication devienne inactif pour qu'il puisse être supprimé. |
SafeSnapshot | En attente de l'obtention d'une image valide pour une transaction
READ ONLY DEFERRABLE . |
SyncRep | En attente de la confirmation d'un serveur distant pour une réplication synchrone. |
XactGroupUpdate | En attente du leader pour la mise à jour du statut de transaction à la fin d'une opération parallélisée. |
Tableau 27.11. Wait Events de type Lock
Wait Event Lock | Description |
---|---|
advisory | En attente de l'acquisition d'un verrou informatif. |
extend | En attente de l'agrandissement d'une relation. |
frozenid | En attente de la mise à jour de
pg_database .datfrozenxid
et pg_database .datminmxid . |
object | En attente de l'acquisition d'un verrou sur un objet de la base qui n'est pas une relation. |
page | En attente de l'acquisition d'un verrou sur une page d'une relation. |
relation | En attente de l'acquisition d'un verrou sur une relation. |
spectoken | En attente de l'acquisition d'un verrou d'insertion spéculatif. |
transactionid | En attente de la fin d'une transaction. |
tuple | En attente de l'acquisition d'un verrou sur une ligne. |
userlock | En attente de l'acquisition d'un verrou utilisateur. |
virtualxid | En attente de l'acquisition d'un verrou sur un identifiant de transaction virtuel. |
Tableau 27.12. Wait Events de type LWLock
Wait Event LWLock | Description |
---|---|
AddinShmemInit | En attente de la gestion d'une allocation d'espace de l'extension dans la mémoire partagée. |
AutoFile | En attente de la mise à jour du fichier
postgresql.auto.conf . |
Autovacuum | En attente de la lecture ou de la mise à jour de l'état courant des workers de l'autovacuum. |
AutovacuumSchedule | En attente de l'assurance qu'une table sélectionnée pour l'autovacuum a toujours besoin d'être traité. |
BackgroundWorker | En attente de la lecture ou de la mise à jour de l'état du background worker. |
BtreeVacuum | En attente de la lecture ou de la mise à jour des informations liées au vacuum pour un index B-tree. |
BufferContent | En attente de l'accès à une page de données en mémoire. |
BufferIO | En attente des I/O sur une page de données. |
BufferMapping | En attente de l'association d'un bloc de données avec un tampon dans le cache. |
Checkpoint | En attente du début d'un checkpoint. |
CheckpointerComm | En attente de la gestion des demandes de fsync. |
CommitTs | En attente de la lecture ou la mise à jour de la dernière valeur pour l'horodatage de la validation d'une transaction. |
CommitTsBuffer | En attente des I/O sur un tampon SLRU d'horodatage de validation de transaction. |
CommitTsSLRU | En attente de l'accès au cache SLRU d'horodatage de validation de transaction. |
ControlFile | En attente de la lecture ou de la mise à jour du fichier
pg_control ou de la création d'un nouveau fichier
WAL. |
DynamicSharedMemoryControl | En attente de lecture ou de la mise à jour des informations d'allocation de mémoire partagée dynamique. |
LockFastPath | En attente de la lecture ou mise à jour des informations du verrou fast-path d'un processus. |
LockManager | En attente de la lecture ou mise à jour des informations sur les verrous « heavyweight ». |
LogicalRepWorker | En attente de la lecture ou de la mise à jour de l'état des workers de réplication logique. |
MultiXactGen | En attente de la lecture ou de la mise à jour de l'état des identifiants partagés de multi-transactions. |
MultiXactMemberBuffer | En attente des I/O sur un tampon SLRU pour les membres multixact. |
MultiXactMemberSLRU | En attente de l'accès au cache SLRU des membres multixact. |
MultiXactOffsetBuffer | En attente des I/O sur un tampon SLRU des décalages multixact. |
MultiXactOffsetSLRU | En attente de l'accès au cache SLRU des décalages multixact. |
MultiXactTruncation | En attente de la lecture ou de la troncature des informations multixact. |
NotifyBuffer | En attente des I/O sur un tampon SLRU pour les messages
NOTIFY . |
NotifyQueue | En attente de la lecture ou de la mise à jour des messages
NOTIFY . |
NotifyQueueTail | En attente de la mise à jour de la limite sur le stockage des
messages NOTIFY . |
NotifySLRU | En attente de l'accçs à un cache SLRU des messages
NOTIFY . |
OidGen | En attente de l'allocation d'un nouvel OID. |
OldSnapshotTimeMap | En attente de la lecture ou de la mise à jour des informations sur le contrôle des images. |
ParallelAppend | En attente de la sélection du prochain sous-plan dans l'exécution d'un nœud Parallel Append. |
ParallelHashJoin | En attente de la synchronisation des workers lors de l'exécution d'un plan Parallel Hash Join. |
ParallelQueryDSA | En attente de l'allocation de la mémoire partagée dynamique pour une requête parallélisée. |
PerSessionDSA | En attente de l'allocation de la mémoire partagée dynamique pour une requête parallélisée. |
PerSessionRecordType | En attente de l'accès aux informations d'une requête parallélisée sur les types composites. |
PerSessionRecordTypmod | En attente de l'accès aux informations d'une requête parallélisée sur les modificateurs de type qui identifient les types de record anonymes. |
PerXactPredicateList | En attente de l'accès à la liste des verrous de prédicat détenus par la transaction sérialisable actuelle lors d'une requête parallélisée. |
PredicateLockManager | En attente de l'accès aux informations de verrou de prédicat utilisées par les transactions sérialisables. |
ProcArray | En attente de l'accès aux structures de données partagées (typiquement, pour obtenir une image ou pour récupérer l'identifiant de transaction d'une session). |
RelationMapping | En attente de la lecture ou de la mise à jour d'un fichier
pg_filenode.map (utilisé pour tracer les affectations
de numéros de fichiers de certains catalogues systèmes). |
RelCacheInit | En attente de la lecture ou de la mise à jour du fichier
d'initialisation du cache des relations,
pg_internal.init . |
ReplicationOrigin | En attente de la création, de la suppression ou de l'utilisation d'une origine de réplication. |
ReplicationOriginState | En attente de la lecture ou la mise à jour de la progression d'une origine de réplication. |
ReplicationSlotAllocation | En attente de l'allocation ou de la libération d'un slot de réplication. |
ReplicationSlotControl | En attente de la lecture ou de la mise à jour d'un état d'un slot de réplication. |
ReplicationSlotIO | En attente des I/O sur un slot de réplication. |
SerialBuffer | En attente des I/O sur un tampon SLRU pour la gestion des conflits des transactions sérialisables. |
SerializableFinishedList | En attente de l'accès à la liste des transactions sérialisées terminées. |
SerializablePredicateList | En attente de l'accès à la liste des verrous de prédicat détenus par les transactions sérialisées. |
SerializableXactHash | En attente de la lecture ou de la mise à jour des informations sur les transactions sérialisables. |
SerialSLRU | En attente de l'accès au cache SLRU de gestion des conflits pour les transactions sérialisées. |
SharedTidBitmap | En attente de l'accès à une bitmap partagé de TID lors d'un parcours d'index bitmap parallélisé. |
SharedTupleStore | En attente de l'accès à un stockage de ligne partagé lors d'une requête parallélisée. |
ShmemIndex | En attente de la recherche ou de l'allocation d'espace en mémoire partagée. |
SInvalRead | En attente de la récupération de messages en provenance de la queue d'invalidation des catalogues partagées. |
SInvalWrite | En attente de l'ajout d'un message dans la queue d'invalidation des catalogues partagées. |
SubtransBuffer | En attente des I/O sur un tampon SLRU d'une sous-transaction. |
SubtransSLRU | En attente de l'accès à un cache SLRU de sous-transaction. |
SyncRep | En attente de la lecture ou de la mise à jour d'informations sur l'état de la réplication synchrone. |
SyncScan | En attente de la sélection de l'emplacement de démarrage d'un parcours synchronisé de table. |
TablespaceCreate | En attente de la création ou suppression d'un tablespace. |
TwoPhaseState | En attente de la lecture ou de la mise à jour de l'état des transactions préparées. |
WALBufMapping | En attente du remplacement d'un bloc dans le cache des WAL. |
WALInsert | En attente de l'insertion de données WAL dans un tampon mémoire. |
WALWrite | En attente que les tampons WAL soient écrits sur disque. |
WrapLimitsVacuum | En attente de la mise à jour des limites sur la consommation des identifiants de transaction et des identifiants multixact. |
XactBuffer | En attente des I/O sur un tampon SLRU de statut de transaction. |
XactSLRU | En attente de l'accès au cache SLRU de statut de transaction. |
XactTruncation | En attente de l'exécution de pg_xact_status
ou de la mise à jour du plus ancien identifiant de transaction
disponible. |
XidGen | En attente de l'allocation d'un nouvel identifiant de transaction. |
Les extensions peuvent ajouter des types LWLock
à la
liste affichée dans le Tableau 27.12. Dans
certains cas, le nom affecté par une extension ne sera pas disponible
dans tous les processus serveurs ; donc un wait
event de type LWLock
pourrait être
rapporté comme simplement une « extension
»
plutôt que comme le nom affecté par l'extension.
Tableau 27.13. Wait Events de type Timeout
Wait Event Timeout | Description |
---|---|
BaseBackupThrottle | En attente pendant la sauvegarde de base lors de la limitation de l'activité. |
PgSleep | En attente suite à un appel à pg_sleep ou à
une fonction du même type. |
RecoveryApplyDelay | En attente de l'application des WAL lors de la restauration à cause du paramétrage d'un délai. |
RecoveryRetrieveRetryInterval | En attente de la restauration quand les données WAL ne sont pas
disponibles quelque soit la source (pg_wal , archive
ou flux). |
VacuumDelay | En attente de la fin d'un délai du VACUUM après dépassement d'un délai. |
Voici un exemple pour voir les wait events :
SELECT pid, wait_event_type, wait_event FROM pg_stat_activity WHERE wait_event is NOT NULL; pid | wait_event_type | wait_event ------+-----------------+------------ 2540 | Lock | relation 6644 | LWLock | ProcArray (2 rows)
pg_stat_replication
La vue pg_stat_replication
contiendra une
ligne par processus d'envoi de WAL, montrant des statistiques sur
la réplication avec le serveur standby connecté au processus. Seuls
les serveurs standby directement connectés sont listés ; aucune
information n'est disponible concernant les serveurs standby en aval.
Tableau 27.14. Vue pg_stat_replication
Type Description |
---|
Identifiant du processus d'envoi des WAL |
OID de l'utilisateur connecté à ce processus |
Nom de l'utilisateur connecté à ce processus |
Nom de l'application qui est connectée à ce processus |
Adresse IP du client connecté à ce processus. Si ce champ est NULL, ceci signifie que le client est connecté via un socket Unix sur la machine serveur. |
Nom de l'hôte du client connecté, comme renvoyé par une
recherche DNS inverse sur |
Numéro du port TCP que le client utilise pour la
communication avec ce processus, ou |
Heure à laquelle ce processus a été démarré, exemple, lorsque le client s'est connecté à ce processus expéditeur de WALs. |
L'horizon |
État courant du processus walsender. Les valeurs possibles sont :
|
La position de la dernière transaction envoyée sur cette connexion |
La position de la dernière transaction écrite sur disque par ce serveur standby |
La position de la dernière transaction vidée sur disque par ce serveur standby |
La position de la dernière transaction rejouée dans la base de données par ce serveur standby |
Durée passée entre le vidage local des WAL récents et la réception
de notification que ce serveur secondaire les a bien écrites (mais pas
encore vidées ou appliquées). Ceci peut être utilisé pour mesurer le
délai que le niveau |
Durée passée entre le vidage local des WAL récents et la réception
de notification que ce serveur secondaire les a bien écrites et vidées
sur disque (mais pas encore appliquées). Ceci peut être utilisé pour
mesurer le délai que le niveau |
Durée passée entre le vidage local des WAL récents et la réception
de notification que ce serveur secondaire les a bien écrites, vidées
sur disque et appliquées. Ceci peut être utilisé pour
mesurer le délai que le niveau |
Priorité de ce serveur standby pour être choisi comme le serveur
|
État synchrone de ce serveur standby. Les valeurs possibles sont :
|
Horodatage d'envoi du dernier message de réponse reçu par le standby |
Les délais rapportés dans la vue
pg_stat_replication
sont des mesures de temps
prises pour l'écriture, le vidage sur disque et le rejeu des données
récentes des WAL et pour que le serveur d'envoi soit mis au courant. Ces
durées représentent le délai de validation qui a été (ou aurait été)
introduit par chaque niveau de validation synchrone si le serveur distant
était configuré comme un standby synchrone. Pour un standby asynchrone, la
colonne replay_lag
renvoie une approximation du
délai avant que les transactions récentes deviennent visibles aux requêtes.
Si le serveur standby a complètement rattrapé le serveur d'envoi et qu'il
n'y a plus d'activité en écriture (donc plus de nouveaux enregistrements
dans les journaux de transactions), les délais mesurés le plus récemment
continueront à être affichés pendant un court instant, puis seront mis à
NULL.
Les délais fonctionnent automatiquement pour la réplication physique. Les plugins de décodage logique pourraient émettre des messages de trace. S'ils ne le font pas, le mécanisme de trace affichera simplement une valeur NULL.
Les délais rapportés ne sont pas des prédictions du temps pris par le
serveur standby pour rattraper le serveur d'envoi en constatant le taux
actuel de rejeu. Un tel système afficherait des temps similaires alors que
de nouveaux journaux de transactions seraient générés, mais différeraient
lorsque le serveur deviendrait inactif. En particulier, quand le serveur
standby a complètement rattrapé le serveur d'envoi,
pg_stat_replication
affiche le temps pris pour
écrire, vider sur disque et rejouer l'emplacement de l'enregistrement le
plus récemment rapporté plutôt que zéro comme certains utilisateurs
pourraient s'y attendre. Ceci est cohérent avec le but de mesurer les
délais de la validation synchrone et de la visibilité des transactions
pour les transactions récentes en écriture. Pour réduire la confusion pour
les utilisateurs s'attendant à un autre modèle de retard, les colonnes de
retard sont réinitialisées à NULL après un court moment sur un système
entièrement à jour et complètement inactif. Les systèmes de supervision
devraient choisir s'ils souhaitent représenter ces colonnes comme des
données manquantes, des données à zéro, ou continuer à afficher la
dernière valeur connue.
pg_stat_wal_receiver
La vue pg_stat_wal_receiver
contiendra seulement
une ligne, affichant les statistiques du walreceiver du serveur de
connexion.
Tableau 27.15. Vue pg_stat_wal_receiver
Type Description |
---|
Identifiant du processus de réception des enregistrements de transaction |
Statut d'activité du processus walreceiver |
Première position dans le journal de transaction utilisée quand walreceiver a été démarré |
Première ligne de temps utilisée quand walreceiver a été démarré |
Dernier emplacement dans les journaux de transactions ayant déjà été reçu et écrit sur disque, mais non vidé du cache. Ceci ne doit pas être utilisé pour des vérifications sur l'intégrité des données. |
Dernier emplacement dans les journaux de transactions ayant déjà été reçu et écrit sur disque, et le cache vidé, la valeur initiale de ce champ étant le premier emplacement utilisé lorsque le processus walreceiver a été démarré. |
Numéro de la ligne de temps de la dernière position des journaux de transactions, déjà reçue et écrite sur disque, la valeur initiale de ce champ étant la ligne de temps de la première position dans les journaux de transactions utilisée lors du démarrage du walreceiver |
Horodatage d'envoi du dernier message reçu à partir du walsender |
Horodatage de la réception du dernier message à partir du walsender |
Dernière position de transaction reportée par le walsender associé |
Horodatage de la dernière position de transaction reportée par le walsender associé |
Nom du slot de réplication utilisé par ce walreceiver |
Hôte de l'instance PostgreSQL auquel ce processus
« wal receiver » est connecté. Il peut s'agir d'un nom d'hôte,
d'une adresse |
Numéro de port de l'instance PostgreSQL auquel wal receiver est connecté. |
Chaîne de connexion utilisée par ce wal receiver, les informations sensibles au niveau sécurité sont cachés. |
pg_stat_subscription
La vue pg_stat_subscription
contiendra une ligne
par souscription du worker principal (avec le PID NULL si le processus
worker n'est pas en cours d'exécution), et des lignes supplémentaires pour
les workers gérant la copie initiale de données des tables souscrites.
Tableau 27.16. Vue pg_stat_subscription
Type Description |
---|
OID de la souscription |
Nom de la souscription |
Identifiant du processus worker de la souscription |
OID de la relation que le processus worker synchronise ; NULL pour le processus worker apply principal |
Dernier emplacement de journal de transactions reçu, la valeur initiale de ce champ étant 0 |
Horodatage d'envoi du dernier message reçu à partir du walsender original |
Horodatage de réception du dernier message reçu du walsender original |
Dernier emplacement des journaux de transactions rapporté par le walsender original |
Horodatage du dernier emplacement de journal de transactions rapporté par le walsender original |
pg_stat_ssl
La vue pg_stat_ssl
contiendra une
ligne par backend ou processus d'envoi de WAL, montrant
des statistiques sur l'usage de SSL dans cette connexion. Elle
peut être jointe à pg_stat_activity
ou pg_stat_replication
sur la colonne
pid
pour obtenir plus de détails sur
la connexion.
Tableau 27.17. Vue pg_stat_ssl
Type Description |
---|
ID du processus backend ou du processus d'envoi de WAL |
True si SSL est utilisé dans cette connexion |
Version de SSL utilisée, ou NULL si SSL n'est pas utilisé pour cette connexion |
Nom du chiffrement SSL utilisé, ou NULL si SSL n'est pas utilisé pour cette connexion |
Nombre de bits dans l'algorithme de chiffrement utilisé, ou NULL si SSL n'est pas utilisé pour cette connexion |
True si la compression SSL est utilisée, false sinon, ou NULL si SSL n'est pas utilisé pour cette connexion |
Champ Distinguished Name (DN) utilisé par le certificat du
client, ou NULL si aucun certificat client n'a été fourni ou si
SSL n'est pas utilisé pour cette connexion. Ce champ est tronqué
si le champ DN est plus long que |
Numéro de série du certificat client ou NULL si aucun certificat n'a été fourni ou si le SSL n'est pas utilisé dans cette connexion. La combinaison du numéro de série du certification et de l'émetteur du certificat identifie de façon unique un certificat (sauf si l'émetteur réutilise par erreur les numéros de série). |
DN de l'émetteur du certificat client ou NULL si aucun certificat
client n'a été fourni ou si le SSL n'est pas utilisé dans cette
connexion. Ce champ est tronqué comme
|
pg_stat_gssapi
La vue pg_stat_gssapi
contient une ligne par
processus serveur, affichant des informations sur l'utilisation de GSSAPI
pour cette connexion. Elle peut être jointe à
pg_stat_activity
ou
pg_stat_replication
sur la colonne
pid
pour obtenir plus de détails sur la
connexion.
Tableau 27.18. Vue pg_stat_gssapi
Type Description |
---|
Identifiant du processus serveur |
True si l'authentification GSSAPI a été utilisée pour cette connexion |
Principal utilisé pour authentifier cette connexion, ou NULL si
GSSAPI n'a pas été utilisé pour authentifier cette connexion. Ce champ
est tronqué si le principal est plus long que
|
True si le chiffrement GSSAPI est utilisé avec cette connexion |
pg_stat_archiver
La vue pg_stat_archiver
aura toujours une seule
ligne contenant les données du processus d'archivage de l'instance.
Tableau 27.19. Vue pg_stat_archiver
Type Description |
---|
Nombre de journaux de transactions archivés avec succès |
Nom du dernier journal de transaction archivé avec succès |
Horodatage de la dernière opération d'archivage réussie |
Nombre d'échecs d'archivage de journaux de transactions |
Nom du journal de transactions correspondant au dernier archivage échoué |
Horodatage de la dernière opération d'archivage échouée |
Horodatage de la dernière réinitialisation de ces statistiques |
pg_stat_bgwriter
La vue pg_stat_bgwriter
aura toujours une ligne
unique, contenant les données globales de l'instance.
Tableau 27.20. Vue pg_stat_bgwriter
Type Description |
---|
Nombre de checkpoints planifiés ayant été effectués |
Nombre de checkpoints demandés ayant été effectués |
Temps total passé dans la partie des checkpoints où les fichiers sont écrits sur disque, en millisecondes. |
Temps total passé dans la partie des checkpoints où les fichiers sont synchronisés sur le disque, en millisecondes. |
Nombre de tampons écrits durant des checkpoints |
Nombre de tampons écrits par le processus background writer (processus d'écriture en tâche de fond) |
Nombre de fois que le processus background writer a arrêté son parcours de nettoyage pour avoir écrit trop de tampons |
Nombre de tampons écrits directement par un processus serveur |
Nombre de fois qu'un processus serveur a du exécuter son propre appel à
|
Nombre de tampons alloués |
Dernière fois que ces statistiques ont été réinitialisées |
pg_stat_database
La vue pg_stat_database
ne contiendra qu'une ligne
pour chaque base de données dans l'instance, plus une pour les objets
partagés, montrant ses statistiques globales.
Tableau 27.21. Vue pg_stat_database
Type Description |
---|
OID d'une base de données, ou 0 pour les objets partagés |
Nom de cette base de données, or |
Nombre de processus serveur actuellement connectés à cette base de
données, ou |
Nombre de transactions de cette base de données qui ont été validées |
Nombre de transactions de cette base de données qui ont été annulées |
Nombre de blocs disques lus dans cette base de données |
Nombre de fois que des blocs disques étaient déjà dans le cache tampon, et qu'il n'a donc pas été nécessaire de les lire sur disque (cela n'inclut que les accès dans le cache tampon de PostgreSQL, pas dans le cache de fichiers du système d'exploitation). |
Nombre de lignes retournées par des requêtes dans cette base de données |
Nombre de lignes rapportées par des requêtes dans cette base de données |
Nombre de lignes insérées par des requêtes dans cette base de données |
Nombre de lignes mises à jour par des requêtes dans cette base de données |
Nombre de lignes supprimées par des requêtes dans cette base de données |
Nombre de requêtes annulées à cause de conflits avec la restauration dans cette
base de données. (Les conflits n'arrivent que sur des serveurs de standby ; voir
|
Nombre de fichiers temporaires créés par des requêtes dans cette base de données. Tous les fichiers temporaires sont comptabilisés, quel que soit la raison de la création du fichier temporaire (par exemple, un tri ou un hachage) et quel que soit la valeur du paramètre log_temp_files. |
Quantité totale de données écrites dans des fichiers temporaires par des requêtes dans cette base de données. Tous les fichiers temporaires sont comptabilisés, quel que soit la raison de la création de ce fichier temporaire, et de la valeur du paramètre log_temp_files. |
Nombre de verrous mortels détectés dans cette base de données |
Nombre d'échecs pour la vérification des sommes de contrôle détectés sur cette base de données (ou sur un objet partagé), ou NULL si les sommes de contrôle ne sont pas activées. |
Horodatage du dernier échec de vérification de somme de contrôle pour un bloc détecté dans cette base (ou sur un objet partagé), ou NULL si les sommes de contrôle ne sont pas activés. |
Temps passé à lire des blocs de donnée dans des fichiers par des processus serveur dans cette base de données, en millisecondes (si track_io_timing est activé, sinon zéro) |
Temps passé à écrire des blocs de données dans des fichiers par les processus serveur dans cette base de données, en millisecondes (si track_io_timing est activé, sinon zéro) |
Dernière fois que ces statistiques ont été réinitialisées |
pg_stat_database_conflicts
Utiliser pg_stat_reset()
réinitialise aussi les
compteurs que l'autovacuum utilise pour déterminer quand déclencher une
opération VACUUM ou une opération ANALYZE. Réinitialiser ces compteurs peut
empêcher l'autovacuum de réaliser un travail pourtant nécessaire, ce qui
entrainerait comme conséquence une fragmentation des tables ou des
statistiques obsolètes sur les données des tables. Un
ANALYZE
sur la base est recommandé après avoir
réinitialisé les statistiques.
La vue pg_stat_database_conflicts
contiendra
une ligne par base de données, montrant des statistiques au niveau
de chaque base de données concernant les requêtes annulées survenant à
cause de conflits avec la restauration sur des serveurs standby. Cette
vue contiendra seulement des informations sur les serveurs standby,
dans la mesure où aucun conflit ne survient sur les serveurs
primaires.
Tableau 27.22. Vue pg_stat_database_conflicts
Type Description |
---|
OID de la base de données |
Nom de cette base de données |
Nombre de requêtes dans cette base de données qui ont été annulées suite à la suppression de tablespaces |
Nombre de requêtes dans cette base de données qui ont été annulées suite à des délais dépassés sur des verrouillages |
Nombre de requêtes dans cette base de données qui ont été annulées à cause d'instantanés trop vieux |
Nombre de requêtes dans cette base de données qui ont été annulées à cause de tampons verrouillés |
Nombre de requêtes dans cette base de données qui ont
été annulées à cause de |
pg_stat_all_tables
La vue pg_stat_all_tables
contiendra une ligne
par table dans la base de données courante (incluant les tables TOAST),
montrant les statistiques d'accès pour cette table spécifiquement. Les vues
pg_stat_user_tables
et
pg_stat_sys_tables
contiennent les mêmes informations,
mais filtrent respectivement les tables utilisateurs et les tables systèmes.
Tableau 27.23. Vue pg_stat_all_tables
Type Description |
---|
OID d'une table |
Nom du schéma dans lequel se trouve cette table |
Nom de cette table |
Nombre de parcours séquentiels initiés sur cette table |
Nombre de lignes vivantes rapportées par des parcours séquentiels |
Nombre de parcours d'index initiés sur cette table |
Nombre de lignes vivantes rapportées par des parcours d'index |
Nombre de lignes insérées |
Nombre de lignes mises à jour (y compris les lignes mises à jour par HOT) |
Nombre de lignes supprimées |
Nombre de lignes mises à jour par HOT (c’est-à-dire sans mises à jour d'index nécessaire) |
Nombre estimé de lignes vivantes |
Nombre estimé de lignes mortes |
Nombre estimé de lignes modifiées depuis le dernier ANALYZE sur cette table |
Nombre estimé de lignes insérées depuis le dernier VACUUM sur cette table |
Dernière fois qu'une opération VACUUM manuelle
a été faite sur cette table (sans compter
|
Dernière fois que le démon autovacuum a exécuté une opération VACUUM sur cette table |
Dernière fois qu'une opération ANALYZE a été lancée manuellement sur cette table |
Dernière fois que le démon autovacuum a exécuté une opération ANALYZE sur cette table |
Nombre de fois qu'une opération VACUUM manuelle a été
lancée sur cette table (sans compter
|
Nombre de fois que le démon autovacuum a exécuté une opération VACUUM manuelle |
Nombre de fois qu'une opération ANALYZE manuelle a été lancée sur cette table |
Nombre de fois que le démon autovacuum a exécuté une opération ANALYZE sur cette table |
pg_stat_all_indexes
La vue pg_stat_all_indexes
contiendra une
ligne pour chaque index dans la base de données courante, montrant les
statistiques d'accès sur cet index spécifiquement. Les vues
pg_stat_user_indexes
et
pg_stat_sys_indexes
contiennent la même
information, mais sont filtrées pour ne montrer respectivement que
les index utilisateurs et les index système.
Tableau 27.24. Vue pg_stat_all_indexes
Type Description |
---|
OID de la table pour cet index |
OID de cet index |
Nom du schéma dans lequel se trouve cet index |
Nom de la table pour cet index |
Nom de cet index |
Nombre de parcours d'index initiés par cet index |
Nombre d'entrées d'index retournées par des parcours sur cet index |
Nombre de lignes vivantes de la table rapportées par des simples parcours d'index utilisant cet index |
Les index peuvent être utilisés avec un simple parcours d'index,
un parcours d'index « bitmap » ou l'optimiseur. Dans un parcours de
bitmap, les sorties de plusieurs index peuvent être combinées avec
des règles AND ou OR, c'est pourquoi il est difficile d'associer des
lectures de lignes individuelles de la table avec des index spécifiques
quand un parcours de bitmap est utilisé. Par conséquent, un parcours de bitmap
incrémente le(s) valeur(s) de pg_stat_all_indexes
.
idx_tup_read
pour le(s) index qu'il utilise, et
incrémente la valeur de pg_stat_all_tables
.
idx_tup_fetch
pour la table, mais il n'affecte pas
pg_stat_all_indexes
.idx_tup_fetch
.
L'optimiseur accède également aux index pour vérifier si des
constantes fournies sont en dehors des plages de valeurs enregistrées
par les statistiques de l'optimiseur car celles-ci peuvent ne pas
être à jour.
Les valeurs de idx_tup_read
et idx_tup_fetch
peuvent être différentes même sans aucune utilisation de parcours
de bitmap, car idx_tup_read
comptabilise les entrées
d'index récupérées de cet index alors que idx_tup_fetch
comptabilise le nombre de lignes vivantes rapportées de la table. Le second sera
moindre si des lignes mortes ou pas encore validées sont rapportées en utilisant
l'index, ou si des lectures de lignes de la table sont évitées grâce à un
parcours d'index seul.
pg_statio_all_tables
La vue pg_statio_all_tables
contiendra
une ligne pour chaque table dans la base de données courante (en
incluant les tables TOAST), montrant les statistiques d'entrées/sorties
de chaque table spécifiquement. Les vues
pg_statio_user_tables
et
pg_statio_sys_tables
contiennent la même
information, mais sont filtrées pour ne montrer respectivement que
les tables utilisateurs et les tables système.
Tableau 27.25. Vue pg_statio_all_tables
Type Description |
---|
OID d'une table |
Nom du schéma dans lequel se trouve cette table |
Nom de cette table |
Nombre de blocs disque lus hors cache pour cette table |
Nombre de blocs disque lus dans le cache pour cette table |
Nombre de blocs disque lus hors cache pour tous les index de cette table |
Nombre de tampons lus dans le cache pour tous les index de cette table |
Nombre de blocs disque lus sur la partie TOAST de cette table (si présente) |
Nombre de tampons récupérés sur la partie TOAST de cette table (si présente) |
Nombre de blocs disque lus sur les index de la partie TOAST de cette table (si présente) |
Nombre de tampons récupérés sur les index de la partie TOAST de cette table (si présente) |
pg_statio_all_indexes
La vue pg_statio_all_indexes
contiendra
une ligne pour chaque index dans la base de données courante,
montrant les statistiques d'entrées/sorties sur chaque index
spécifiquement. Les vues
pg_statio_user_indexes
et
pg_statio_sys_indexes
contiennent la même
information, mais sont filtrées pour ne montrer respectivement
que les tables utilisateur et tables système.
Tableau 27.26. Vue pg_statio_all_indexes
Type Description |
---|
OID de la table pour cet index |
OID de cet index |
Nom du schéma dans lequel se trouve cet index |
Nom de la table pour cet index |
Nom de cet index |
Nombre de blocs disque lus pour cet index |
Nombre de tampons récupérés sur cet index |
pg_statio_all_sequences
La vue pg_statio_all_sequences
contiendra
une ligne pour chaque séquence dans la base de données courante,
montrant les statistiques d'entrées/sorties pour chaque séquence spécifiquement.
Tableau 27.27. Vue pg_statio_all_sequences
Type Description |
---|
OID de cette séquence |
Nom du schéma dans lequel se trouve cette séquence |
Nom de cette séquence |
Nombre de blocs disque lus pour cette séquence |
Nombre de tampons récupérés pour cette séquence |
pg_stat_user_functions
La vue pg_stat_user_functions
contiendra une
ligne pour chaque fonction suivie, montrant les statistiques d'exécution
de cette fonction. Le paramètre track_functions
contrôle exactement quelles fonctions sont suivies.
Tableau 27.28. Vue pg_stat_user_functions
Type Description |
---|
OID de cette fonction |
Nom du schéma dans lequel se trouve cette fonction |
Nom de cette fonction |
Nombre de fois que cette fonction a été appelée |
Temps total passé dans cette fonction ainsi que dans toutes les autres fonctions appelées par elle, en millisecondes |
Temps total passé dans cette fonction seule, sans inclure les autres fonctions appelées par elle, en millisecondes |
pg_stat_slru
PostgreSQL accède à certaines informations
stockées sur disque via des caches SLRU
(simple least-recently-used). La vue
pg_stat_slru
contiendra une ligne pour chaque
cache SLRU tracé, affichant des statistiques sur l'accès aux pages cachées.
Tableau 27.29. Vue pg_stat_slru
Type Description |
---|
Nom du cache SLRU |
Nombre de blocs initialisés à zéro |
Nombre de fois que les blocs disques ont été trouvés dans le cache SLRU, et donc qu'une lecture disque n'était pas nécessaire (ceci inclut seulement les lectures dans le cache SLRU, pas les lectures dans le cache du système d'exploitation) |
Nombre de blocs disques lus à partir de ce cache SLRU |
Nombre de blocs disques écrit dans ce cache SLRU |
Nombre de blocs dont l'existence a été vérifiée dans ce cache SLRU |
Nombre de vidages de données modifiées pour ce cache SLRU |
Nombre de troncatures pour ce cache SLRU |
Horodatage de la dernière réinitialisation de ces statistiques |
Une autre façon de regarder les statistiques peut être mise en place
en écrivant des requêtes utilisant les mêmes fonctions d'accès sous-
jacentes utilisées par les vues standards montrées au-dessus. Pour
des détails comme les noms de fonction, veuillez consulter les définitions
de ces vues standards. (Par exemple, dans psql
vous pouvez utiliser \d+ pg_stat_activity
.)
Les fonctions d'accès pour les statistiques par base de données prennent
comme argument un OID pour identifier sur quelle base de données travailler.
Les fonctions par table et par index utilisent un OID de table ou d'index.
Les fonctions pour les statistiques par fonctions utilisent un OID de fonction.
Notez que seuls les tables, index et fonctions dans la base de données
courante peuvent être vus avec ces fonctions.
Les fonctions supplémentaires liées à la récupération de statistiques sont listées dans Tableau 27.30.
Tableau 27.30. Fonctions supplémentaires de statistiques
pg_stat_get_activity
, la fonction sous-jacente de la
vue pg_stat_activity
, retourne un ensemble
d'enregistrements contenant toute l'information disponible sur chaque
processus serveur. Parfois il peut être plus pratique de n'obtenir qu'un
sous-ensemble de cette information. Dans ces cas-là, un ensemble plus vieux
de fonctions d'accès aux statistiques par processus serveur peut être
utilisé ; celle-ci sont montrées dans Tableau 27.31. Ces fonctions d'accès
utilisent un numéro d'identifiant du processus serveur, qui va de un au
nombre de processus serveur actuellement actifs. La fonction
pg_stat_get_backend_idset
fournit une manière pratique
de générer une ligne pour chaque processus serveur actif pour appeler ces
fonctions. Par exemple, pour montrer les PID et requêtes
en cours de tous les processus serveur :
SELECT pg_stat_get_backend_pid(s.backendid) AS pid, pg_stat_get_backend_activity(s.backendid) AS query FROM (SELECT pg_stat_get_backend_idset() AS backendid) AS s;
Tableau 27.31. Fonctions statistiques par processus serveur
Fonction Description |
---|
Ensemble de numéros de processus serveur actuellement actifs (de 1 jusqu'au nombre de processus serveur actifs) |
Texte de la requête la plus récente de ce processus serveur |
Heure à laquelle la requête la plus récente a été démarrée |
Adresse IP du client connecté à ce processus serveur |
Numéro de port TCP que le client utilise pour communiquer |
OID de la base de données auquel ce processus serveur est connecté |
Identifiant du processus serveur |
Heure à laquelle ce processus a été démarré |
OID de l'utilisateur connecté à ce processus serveur |
Nom du type d'événement d'attente si le processus est actuellement en attente, NULL sinon. Voir Tableau 27.4 pour les détails. |
Nom de l'événement d'attente si le processus est actuellement en attente, NULL sinon. Voir Tableau 27.4 pour les détails. |
Heure à laquelle la transaction courante a été démarrée |