activite_postgres
Différences
Ci-dessous, les différences entre deux révisions de la page.
| Les deux révisions précédentesRévision précédenteProchaine révision | Révision précédente | ||
| activite_postgres [2020/05/08 19:15] – [Les verrous] fraynaud | activite_postgres [2020/06/08 15:55] (Version actuelle) – fraynaud | ||
|---|---|---|---|
| Ligne 1: | Ligne 1: | ||
| - | =====Monotoring | + | ======Monitoring |
| + | |||
| + | --- // | ||
| Dans ce chapître, nous allons récupérer les statistiques d' | Dans ce chapître, nous allons récupérer les statistiques d' | ||
| Ligne 5: | Ligne 7: | ||
| [[https:// | [[https:// | ||
| - | ====Processeurs==== | + | ====Processus==== |
| - | Processeur | + | Processus |
| < | < | ||
| Ligne 23: | Ligne 25: | ||
| la récupération de statistiques (stats collector) ajoute un temps supplémentaire à l' | la récupération de statistiques (stats collector) ajoute un temps supplémentaire à l' | ||
| - | activité du serveur postgres (1 ligne par processeur | + | activité du serveur postgres (1 ligne par processus |
| < | < | ||
| select pid, | select pid, | ||
| Ligne 31: | Ligne 33: | ||
| 507 | | | 507 | | | ||
| 509 | postgres | | 509 | postgres | | ||
| - | 4207 | deb | openstock | + | 4207 | deb | openstock |
| 505 | | | 505 | | | ||
| 504 | | | 504 | | | ||
| Ligne 75: | Ligne 77: | ||
| ==== TABLES ==== | ==== TABLES ==== | ||
| - | |||
| - | < | ||
| pg_stat_all_tables pg_stat_sys_tables pg_stat_user_tables | pg_stat_all_tables pg_stat_sys_tables pg_stat_user_tables | ||
| + | < | ||
| select * from pg_stat_user_tables where relname =' | select * from pg_stat_user_tables where relname =' | ||
| + | |||
| relid|27036 schemaname|public relname|jpa | relid|27036 schemaname|public relname|jpa | ||
| seq_scan|4 | seq_scan|4 | ||
| Ligne 93: | Ligne 95: | ||
| ==== INDEX ==== | ==== INDEX ==== | ||
| - | |||
| - | < | ||
| pg_stat_all_indexes pg_stat_sys_indexes pg_stat_user_indexes | pg_stat_all_indexes pg_stat_sys_indexes pg_stat_user_indexes | ||
| + | < | ||
| select * from pg_stat_user_indexes where relname=' | select * from pg_stat_user_indexes where relname=' | ||
| + | |||
| relid|18236 | relid|18236 | ||
| indexrelid|18243 | indexrelid|18243 | ||
| Ligne 116: | Ligne 118: | ||
| ==== VACCUM et ANALYZE ==== | ==== VACCUM et ANALYZE ==== | ||
| + | [[https:// | ||
| + | |||
| + | VACUUM — récupère l' | ||
| + | A faire sur les tables frequemment mises à jour. | ||
| + | |||
| + | < | ||
| + | |||
| + | vacuum verbose openstock_association.facture; | ||
| + | |||
| + | INFO: vacuuming " | ||
| + | INFO: index " | ||
| + | DETAIL: | ||
| + | 0 index pages have been deleted, 0 are currently reusable. | ||
| + | CPU 0.00s/0.00u sec elapsed 0.00 sec. | ||
| + | INFO: " | ||
| + | DETAIL: | ||
| + | There were 5 unused item pointers. | ||
| + | Skipped 0 pages due to buffer pins. | ||
| + | 0 pages are entirely empty. | ||
| + | CPU 0.00s/0.00u sec elapsed 0.00 sec. | ||
| + | INFO: vacuuming " | ||
| + | INFO: index " | ||
| + | DETAIL: | ||
| + | 0 index pages have been deleted, 0 are currently reusable. | ||
| + | CPU 0.00s/0.00u sec elapsed 0.00 sec. | ||
| + | INFO: " | ||
| + | DETAIL: | ||
| + | There were 0 unused item pointers. | ||
| + | Skipped 0 pages due to buffer pins. | ||
| + | 0 pages are entirely empty. | ||
| + | CPU 0.00s/0.00u sec elapsed 0.00 sec. | ||
| + | Query returned successfully with no result in 92 msec. | ||
| + | |||
| + | analyse verbose openstock_association.facture; | ||
| + | |||
| + | INFO: analyzing " | ||
| + | INFO: " | ||
| + | Query returned successfully with no result in 34 msec. | ||
| + | |||
| + | |||
| + | VACUUM VERBOSE ANALYZE openstock_association.facture; | ||
| + | |||
| + | </ | ||
| + | |||
| + | ===Recommandations=== | ||
| + | |||
| + | * planifier un VACUUM général sur toute la base une fois par jour, en dehors des horaires normaux de production | ||
| + | * VACUUM FULL est recommandé dans les cas où vous savez que vous avez supprimé la majorité des lignes dans une table | ||
| + | * TRUNCATE (au lieu de delete) supprime le contenu entier de la table immédiatement sans nécessiter un VACUUM ou VACUUM FULL pour réclamer l' | ||
| + | |||
| + | ==== autovacuum ==== | ||
| + | |||
| + | autovacuum (boolean): | ||
| + | (paramètre de postgresql.conf). track_counts doit être aussi activé (statistiques) | ||
| + | |||
| + | < | ||
| + | # | ||
| + | # AUTOVACUUM | ||
| + | # | ||
| + | |||
| + | #autovacuum = on # Enable autovacuum subprocess? | ||
| + | # requires track_counts to also be on. | ||
| + | |||
| + | </ | ||
| + | |||
activite_postgres.1588965306.txt.gz · Dernière modification : de fraynaud
