PostgreSQL La base de donnees la plus sophistiquee au monde.

Forums PostgreSQL.fr

Le forum officiel de la communauté francophone de PostgreSQL

Vous n'êtes pas identifié(e).

#1 09/01/2018 22:50:34

pitpoule
Membre

Taille mémoire maximale d'un process backend

Bonjour,

J'aimerais savoir quelle est la taille maximale que peut occuper en mémoire un process backend ? Je connais les paramètres work_mem, maintenance_work_mem et temp_buffers.
Mais que se passe t'il si je lance une requête qui ramène 5 Go de données ? Et pour corser le tout cette requête possède de nombreux noeuds d'exécution.
Est ce que l'exécuteur stocke les infos en mémoire ou bien les envoie t'il en "flux" au client ?


Merci

PS: J'espère que ma question est  assez claire :s

Hors ligne

#2 10/01/2018 10:08:23

ruizsebastien
Membre

Re : Taille mémoire maximale d'un process backend

Bonjour,

Je peux emmener juste une partie de la réponse, notre spécialiste du moteur PostgreSQL (Gleu) complétera certainement.
Votre requête va utiliser une ou plusieurs zone de mémoire :
shared_buffer pour les blocs de données en RAM
work_mem pour les tris.
Les zone mémoires sont utilisées à concurrence de ce que vous avez fixé dans postgresql.conf.
Si il y a besoin de plus de mémoire (pour les tris) il y aura production de fichiers temporaire sur disque.
Le danger avec work_mem c'est d'exploser la RAM si ce paramètre est trop élevé (risque de swap) ou de créer trop de fichiers sur disque si trop bas.
La est toute la difficulté.

Cordialement.


Cordialement,

Sébastien.

Hors ligne

#3 10/01/2018 16:06:10

pitpoule
Membre

Re : Taille mémoire maximale d'un process backend

Je me pose a question au niveau de la résolution des jointures des plans d'exécution. Par exemple les hash join et merge join vont s'exécuter dans la work_mem.... mais le nested join ? Il n'y a pas de tri, juste deux boucles imbriquées. De ce que je comprends, ça doit être au niveau de l'exécuteur du backend.

Dernière modification par pitpoule (10/01/2018 16:49:16)

Hors ligne

#4 11/01/2018 17:57:20

superette
Membre

Re : Taille mémoire maximale d'un process backend

bonjour pitpoule,

Il y a une instance de work_mem utilisée par nœud de requête, donc, une requête avec un JOIN va utiliser 2 work_mem, un tri utilise un work_mem de plus, et ainsi de suite.

Le danger d'un work_mem trop élevé ce n'est pas seulement de faire du swap, c'est de se retrouver avec un oom-killer qui peux tuer le processus postmaster de postgres, ce qui peut entraîner des corruptions de données.

Pour s'en protéger, configurer

vm.overcommit_ratio
avec
vm.overcommit_memory = 2

définir vm.overcommit_ratio en suivant la formule suivante :

overcommit_ratio=target_ratio-(100/TOTAL RAM)*SWAP SIZE

target_ratio à 90 pour 90% est une valeur raisonnable.

Hors ligne

#5 12/01/2018 03:34:43

rjuju
Administrateur

Re : Taille mémoire maximale d'un process backend

Je précise que le déclenchement de l'OOM killer peut tuer brutalement le postmaster, mais cela ne corrompra pas l'instance.  Par contre arrêt de service, perte du cache etc.

Hors ligne

#6 12/01/2018 15:52:52

gleu
Administrateur

Re : Taille mémoire maximale d'un process backend

pitpoule, pas besoin de mémoire pour un Nested Loop. Comme vous le dites, ce sont deux boucles imbriquées parcourues en même temps. Le backend a besoin de garder en mémoire uniquement la ligne en cours de traitement pour la la relation externe (et encore, elle est dans le cache). Donc non, vraiment aucune mémoire spécifique.


Guillaume.

Hors ligne

#7 12/01/2018 18:33:13

pitpoule
Membre

Re : Taille mémoire maximale d'un process backend

gleu a écrit :

pitpoule, pas besoin de mémoire pour un Nested Loop. Comme vous le dites, ce sont deux boucles imbriquées parcourues en même temps. Le backend a besoin de garder en mémoire uniquement la ligne en cours de traitement pour la la relation externe (et encore, elle est dans le cache). Donc non, vraiment aucune mémoire spécifique.

Donc la taille mémoire utilisée par un backend ne dépendra que des valeurs de work_mem, temp_buffers et maintenance_work_mem ?

Hors ligne

#8 13/01/2018 09:12:51

gleu
Administrateur

Re : Taille mémoire maximale d'un process backend

Non, mais on n'a pas d'autres moyens de l'estimer.


Guillaume.

Hors ligne

#9 18/01/2018 17:41:13

pitpoule
Membre

Re : Taille mémoire maximale d'un process backend

Ah.... du coup, j'en reviens à mon post initial... qu'est ce qui occupe de la mémoire au niveau du backend ? (en dehors de work_mem, maintenance_work_mem et temp_buffers ?

Hors ligne

#10 18/01/2018 18:00:16

ruizsebastien
Membre

Re : Taille mémoire maximale d'un process backend

shared_buffers
wal_buffers
autovacuum_work_mem


Cordialement,

Sébastien.

Hors ligne

#11 18/01/2018 22:21:44

gleu
Administrateur

Re : Taille mémoire maximale d'un process backend

shared_buffers et wal_buffers ne prennent pas de mémoire locale pour le backend. Le backend peut les utiliser mais c'est de la mémoire partagée.

Quant à la question initiale, il n'y a pas de paramètre pour le reste.


Guillaume.

Hors ligne

Pied de page des forums