Dans ce scénario, le serveur MySQL sur une instance micro EC2 plante à plusieurs reprises avec l'erreur "InnoDB: mmap (x bytes) failed; errno 12." Malgré les tentatives de redémarrage du serveur, le problème persiste. En examinant les journaux MySQL, il devient évident que l'initialisation du pool de mémoire tampon InnoDB échoue en raison d'une allocation de mémoire insuffisante.
Le pool de mémoire tampon InnoDB stocke les données fréquemment consultées en mémoire pour optimiser la performance des opérations de base de données. Cependant, dans ce cas, la capacité mémoire limitée de la micro-instance empêche l’allocation d’un espace suffisant pour le pool de mémoire tampon. Par conséquent, InnoDB ne parvient pas à s'initialiser et le serveur MySQL se termine avec le message d'erreur.
Pour résoudre ce problème, il est recommandé de créer un espace d'échange, qui agit essentiellement comme un espace d'échange supplémentaire. mémoire virtuelle. Cela permet au système d'exploitation d'utiliser l'espace disque inutilisé comme RAM, augmentant ainsi la mémoire disponible pour les opérations critiques comme InnoDB.
La création d'un espace d'échange implique les étapes suivantes :
dd if=/dev/zero of=/swapfile bs=1M count=1024
mkswap /swapfile
swapon /swapfile
/swapfile swap swap defaults 0 0
Si la création d'un espace d'échange ne résout pas le problème, une solution alternative consiste à utiliser Amazon RDS (Relational service de base de données). RDS est un service de base de données géré d'AWS qui fournit des instances de base de données dédiées avec des ressources de mémoire et de stockage garanties. En migrant la base de données vers une instance RDS, le problème de l'allocation de mémoire limitée sur la micro-instance peut être contourné.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!