2 votes

MySQL se bloque et ne parvient pas à redémarrer

MySQL semble se bloquer, normalement plus tard dans la journée, mais je ne vois pas pourquoi ! Il dit qu'il n'y a plus de mémoire, mais il y a beaucoup de mémoire libre et aucun espace d'échange n'est utilisé. J'utilise Azure.

Voici le journal :

Oct  3 20:42:20 GenyxLive kernel: [787828.711240] Out of memory: Kill process 53891 (mysqld) score 84 or sacrifice child
Oct  3 20:42:20 GenyxLive kernel: [787828.714081] Killed process 53891 (mysqld) total-vm:871780kB, anon-rss:58164kB, file-rss:0kB
Oct  3 20:42:20 GenyxLive kernel: [787828.731974] init: mysql main process (53891) killed by KILL signal
Oct  3 20:42:20 GenyxLive kernel: [787828.733525] init: mysql main process ended, respawning
Oct  3 20:42:20 GenyxLive kernel: [787828.974636] init: mysql main process (24975) terminated with status 1
Oct  3 20:42:20 GenyxLive kernel: [787828.974666] init: mysql main process ended, respawning
Oct  3 20:42:21 GenyxLive kernel: [787829.937186] init: mysql post-start process (24976) terminated with status 1
Oct  3 20:42:22 GenyxLive kernel: [787830.103158] init: mysql main process (25002) terminated with status 1
Oct  3 20:42:22 GenyxLive kernel: [787830.103194] init: mysql respawning too fast, stopped

Voici le graphique de ce qui se passe : graph

Vous pouvez voir un pic de cpu et ensuite le service mysql s'arrête...

Quelqu'un peut-il m'aider à comprendre ce qui se passe ?

Ubuntu 12.04

Azure Small (768mb ram, 1ghz cpu)

EDITAR

Il y a une tâche cron qui s'exécute toutes les 5 minutes et qui vérifie les nouveaux domaines, etc (en utilisant zpanel).

C'est un système d'exploitation 64 bits

Linux GenyxLive 3.2.0-48-virtual #74-Ubuntu SMP Thu Jun 6 20:02:55 UTC 2013 x86_64 x86_64 x86_64 GNU/Linux

free -lm résultat :

             total       used       free     shared    buffers     cached
Mem:           672        491        180          0         42        118
Low:           672        491        180
High:            0          0          0
-/+ buffers/cache:        330        341
Swap:            0          0          0

cat /proc/meminfo résultat :

MemTotal:         688348 kB
MemFree:          186788 kB
Buffers:           43956 kB
Cached:           120988 kB
SwapCached:            0 kB
Active:           335908 kB
Inactive:          84924 kB
Active(anon):     255976 kB
Inactive(anon):      296 kB
Active(file):      79932 kB
Inactive(file):    84628 kB
Unevictable:           0 kB
Mlocked:               0 kB
SwapTotal:             0 kB
SwapFree:              0 kB
Dirty:                16 kB
Writeback:             0 kB
AnonPages:        255924 kB
Mapped:            18568 kB
Shmem:               376 kB
Slab:              51788 kB
SReclaimable:      37052 kB
SUnreclaim:        14736 kB
KernelStack:        1344 kB
PageTables:         7632 kB
NFS_Unstable:          0 kB
Bounce:                0 kB
WritebackTmp:          0 kB
CommitLimit:      344172 kB
Committed_AS:     967220 kB
VmallocTotal:   34359738367 kB
VmallocUsed:       13192 kB
VmallocChunk:   34359723128 kB
HardwareCorrupted:     0 kB
AnonHugePages:         0 kB
HugePages_Total:       0
HugePages_Free:        0
HugePages_Rsvd:        0
HugePages_Surp:        0
Hugepagesize:       2048 kB
DirectMap4k:       51136 kB
DirectMap2M:      735232 kB

2voto

user192576 Points 263

L'OOM du noyau n'intervient que lorsqu'il considère que les ressources sont vraiment limitées... vous devez donc manquer de mémoire, mais le graphique n'a pas beaucoup de sens dans ce cas.

Qu'est-ce que free -lm spectacle ? De plus, que fait le cat /proc/meminfo spectacle ?

Pour ce qui est de l'élément déclencheur du problème, est-ce qu'un processus de maintenance ou un autre travail cron s'exécute à cette période, qui pourrait effectuer des requêtes pour lesquelles mysql doit maintenir des tables temporaires en mémoire ?

BTW... s'agit-il d'une version 32 bits du système d'exploitation ? Je me demande simplement si votre faible mémoire est épuisée.

EDIT 1 D'accord. Eh bien, mysqld est le processus qui consomme le plus de mémoire, c'est donc probablement la raison pour laquelle il est sollicité. Vérifiez votre configuration Apache pour voir combien de threads de travail vous créez... chacun aura une surcharge de mémoire et il est possible que lorsque plus de threads sont créés, vous manquiez de mémoire car vous n'avez pas d'espace d'échange. Vérifiez votre paramètre MaxClients... si vous en avez plus de 50 (juste un chiffre approximatif), c'est un bon endroit pour regarder. Puis-je vous recommander de jeter un coup d'œil à Optimisation des performances d'Apache .

SistemesEz.com

SystemesEZ est une communauté de sysadmins où vous pouvez résoudre vos problèmes et vos doutes. Vous pouvez consulter les questions des autres sysadmins, poser vos propres questions ou résoudre celles des autres.

Powered by:

X