Migration de MyISAM vers InnoDB

De MoodleDocs
Aller à :navigation, rechercher

Cette page concerne les sites Moodle utilisant MySQL, et devrait contenir toutes les informations nécessaires pour prendre une décision concernant le changement de moteur de données pour passer à InnoDB (au lieu de MyISAM). Elle a été créée suite à cette discussion.

Pourquoi passer de MyISAM à InnoDB

InnoDB sera plus adapté pour une montée en charge importante. Pour des petits sites, son utilisation est moins utile.

Différences entre MyISAM et InnoDB

  • Lisez [1]
  • InnoDB est meilleur pour l'intégrité des données, moins bon pour la recherche dans de gros fichiers, et utilise plus de ressources CPU et d'espace de stockage (jusqu'à 2 ou 3 fois plus) que MyISAM
  • InnoDB est plus jeune que MyISAM, mais devient de plus en plus attrayant... mais étant plus complexe, certains utilitaires écrit pour MyISAM comme mysqlhotcopy peuvent ne pas fonctionner
  • Lors d'une modification dans une table, MyISAM verrouille la table entière (ce qui "bloque" les autres mises à jour) alors qu'InnoDB ne verrouille que l'enregistrement concerné (il est donc plus facile de réaliser plusieurs opérations en "quasi simultané") : en bref, plus un site est utilisé, plus l'avantage d'InnoDB sera notable
  • Il est parfaitement possible d'utiliser InnoDB pour certaines tables, et MyISAM pour d'autres (selon les critères ci-dessus)

Configuration MySQL

Avant de tenter de changer le type de table, vous devriez :

  • Vérifier qu'InnoDB est activé. Connectez-vous à MySQL et lancez la commande SHOW ENGINES. Assurez vous que le support pour InnoDB montre "YES" ou "DEFAULT".
  • Activer innodb_file_per_table si nécessaire. Ce paramètre peut être utile pour de grosses installations, mais s'applique uniquement aux nouvelles tables créées et ne peut être appliqué après coup.

Différentes façon de migrer de MyISAM à InnoDB

Il suffit d'utiliser une des méthodes ci-dessous, qui correspond le plus à votre cas, et vos possibilités.

  • Activez le mode de maintenance, et exécutez le script depuis la page web :
    • Depuis Moodle 2.2 : http://www.MON_SITE_MOODLE.fr/admin/tool/innodb (Vous devez être connecté en tant qu'administrateur)
    • Pour Moodle 1.9, 2.0 et 2.1 : http://www.MON_SITE_MOODLE.fr/admin/innodb.php
Attention, il peut y avoir des problèmes de timeout sur les grandes bases de données.
Ajoutez au fichier /etc/my.cnf sous la section [mysqld] une ligne "binlog_format=ROW" (sans les guillemets) et arrêtez puis redémarrez MySQL. Sans cela, vous risquez de rencontrer l'erreur dmlwriteexception lorsque Moodle essaie d'écrire vers MySQL.
  • Utilisez le script en ligne de commande (depuis Moodle 2.0) dans admin/cli/mysql_engine.php (nécessite l'accès au shell, et le fichier config.php doit n'avoir qu'une seule instance Moodle, mais il n'y a aucun problème de timeout) - Moodle 2.x uniquement !
  • Utilisez PHPMyAdmin en entrant dans la vue de la structure d'une table et cliquez sur l'onglet Opérations. Recherchez les paramètres du moteur de stockage. Il s'agit d'une tâche fastidieuse à cause du nombre de tables [2]
  • Effectuez un dump de base de données (par exemple : mysqldump moodle_database > dump.sql), utilisez un éditeur ou des commandes sed/perl/awk pour trouver/remplacer MyISAM par InnoDB. Enfin, restaurez votre base dans le serveur (mysql < dump.sql ou équivalent). Attention : si vous utilisez cette méthode, assurez vous d'utiliser le même encodage lors du dump et de l'import !
  • Suivez le processus détaillé ici : https://sites.google.com/site/moodlemayhem/tcea2011-moodle-server-setup-basics/moodleacidtrip
  • Utilisez le script PHP suivant : http://noveckg.blogspot.com/2012/04/moodle-php-script-to-convert-mysql.html

Retours d'expérience

Vous avez migré, n'hésitez pas à ajouter vos retours d'expérience : temps de traitement, en liaison avec la taille de votre base, éventuels problèmes rencontrés et solutions trouvées...

Voir aussi