MySQL 8.x – Optimisation

Dernière mise à jour : 17 juillet 2023

Open Source

Plongez dans l’optimisation de MySQL avec notre formation « MySQL 8.
x – Optimisation ».
Elle vise à fournir une compréhension détaillée du fonctionnement et de l’architecture du serveur MySQL pour optimiser son utilisation.
Découvrez comment mesurer la performance de votre base de données en analysant les facteurs limitants tels que l’accès aux disques, la mémoire, le CPU et le réseau.
Apprenez à utiliser les outils d’analyse des performances et à configurer votre serveur pour une optimisation maximale.
Nous vous guiderons à travers les principes de la journalisation, l’utilisation de la mémoire et le fonctionnement des principaux moteurs de stockage.
Apprenez comment analyser et optimiser les requêtes et l’utilisation des index.
Découvrez l’ordonnanceur d’événements et son utilisation pour optimiser les performances.
Enfin, maîtrisez l’optimisation du partitionnement des tables pour améliorer les performances de votre base de données.

Objectifs pédagogiques


  • Décrire le fonctionnement de MySQL à des fins d'optimisation ;
  • Utiliser des outils d'analyse des performances et les journaux et savoir analyser leurs données ;
  • Optimiser le recours à la mémoire ;
  • Analyser le plan d'exécution des requêtes afin de les optimiser ;
  • Optimiser l'utilisation des index ;
  • Utiliser l'ordonnanceur d'événements ;
  • Optimiser le partitionnement des tables.

Public concerné


Administrateur et développeurs MySQL.

Prérequis


Avoir suivi le cours T240-020 – MySQL 5.x Administration, ou posséder les connaissances et compétences équivalentes.

Programme détaillé


Mesure de la performance

  • Problématique : les facteurs limitants
    • Accès disques
    • Mémoire
    • CPU
    • Réseau
  • Quelques outils généralistes d'analyse
  • Travaux pratiques :
    • Prise en main des outils d'analyse des performances sous Linux

Présentation du serveur

  • Architecture de MySQL
  • Variables de connexion
  • Variables de statut
  • Travaux pratiques :
    • Parcours de la configuration courante et des variables de statut

Journalisation

  • Principe
  • Journalisation des requêtes
  • Journalisation des requêtes lentes
  • Journalisation des requêtes non indexées
  • Travaux pratiques :
    • Mise en œuvre des différentes journalisations

Utilisation de la mémoire

  • Mémoire globale
  • Mémoire par connexion
  • Présentation des différents caches
    • Cache de threads
    • Cache de tables
    • Cache de requêtes
  • Caches liés aux moteurs de stockage
  • Travaux pratiques :
    • Configuration mémoire globale

Principaux moteurs de stockage

  • MyIsam
    • Formats des enregistrements
    • Cache de clés d'index
  • InnoDB
    • Présentation du fonctionnement général
    • Cache global
    • Sauvegarde/Restauration du cache global
    • Gestion des logs
    • Compression des tables
  • Memory
    • Caractéristiques
    • Utilisation
    • Configuration
    • Limitations
  • CSV
    • Principes
    • Utilisation
    • Journalisation requêtes/requêtes lentes
    • Exportation/Importation
    • Limitations
  • Archive
    • Caractéristiques
    • Limitations
  • Travaux pratiques :
    • Configuration des moteurs MyISAM et InnoDB

Analyse du plan d'exécution

  • Principe de la commande EXPLAIN
  • Informations de la commande EXPLAIN
  • EXPLAIN EXTENDED

Optimisation des requêtes

  • Coût d'une requête
  • Isolation des colonnes
  • Écriture des jointures
  • Filtrages
  • Tris
  • Agrégations
  • Group By
  • Utilisation des index
  • Problématique des tables temporaires
  • Problématique du cache de requêtes
  • Travaux pratiques :
    • Mise en œuvre des différents " cas d'école "

Gestion des index

  • Présentation des index
  • Intérêts des index
  • Vérification de l'utilisation des index
    • Commande EXPLAIN
    • Compteurs de status
  • Indications pour l'optimiseur
    • USE INDEX()
    • FORCE INDEX()
    • NO INDEX()
  • Travaux pratiques :
    • Mise en œuvre des index

Ordonnanceur d'événements

  • Présentation
  • Configuration : activation/désactivation
  • Privilège d'utilisation
  • Gestion des événements
    • Création d'un événement
    • Modification d'un événement
    • Activation/désactivation d'un événement
  • Consultation des événements
  • Travaux pratiques :
    • Interruption programmée de la réplication par l'ordonnanceur interne de MySQL

Partitionnement de tables

  • Principe
  • Type de partitionnement
  • Choix explicite d'une partition
  • Sous-partitionnement
  • Restrictions
  • Fonctions du partitionnement
  • Travaux pratiques :
    • Mise en œuvre des différentes politiques de partitionnement

Modalités et moyens pédagogiques, techniques et d'encadrement


Formation avec un formateur, qui peut être suivie selon l'une des 3 modalités ci-dessous :

1 - Dans la salle de cours en présence du formateur.

2 – Dans l'une de nos salles de cours immersives, avec le formateur présent physiquement à distance. Les salles immersives sont équipées d’un système de visio-conférence HD et complétées par des outils pédagogiques qui garantissent le même niveau de qualité.

3 – Depuis votre domicile ou votre entreprise. Vous rejoignez un environnement de formation en ligne, à l'aide de votre ordinateur, tout en étant éloigné physiquement du formateur et des autres participants. Vous êtes en totale immersion avec le groupe et participez à la formation dans les mêmes conditions que le présentiel. Pour plus d'informations: Le téléprésentiel – notre solution de formation à distance.

Le nombre de stagiaires peut varier de 1 à 12 personnes (5 à 6 personnes en moyenne), ce qui facilite le suivi permanent et la proximité avec chaque stagiaire.

Chaque stagiaire dispose d’un poste de travail adapté aux besoins de la formation, d’un support de cours et/ou un manuel de référence au format numérique ou papier (pour les sessions inter-entreprises, dans le cas où le support de cours officiel est en anglais, nous offrons en complément, s’il existe, un ouvrage de référence des Editions ENI au format numérique rédigé en français).

Pour une meilleure assimilation, le formateur alterne tout au long de la journée les exposés théoriques, les démonstrations et la mise en pratique au travers d'exercices et de cas concrets réalisés seul ou en groupe.

Modalités d'évaluation des acquis


En début et en fin de formation, les stagiaires réalisent une auto-évaluation de leurs connaissances et compétences en lien avec les objectifs de la formation. L'écart entre les deux évaluations permet ainsi de mesurer leurs acquis.

En complément, pour les stagiaires qui le souhaitent, certaines formations peuvent être validées officiellement par un examen de certification. Les candidats à la certification doivent produire un travail personnel important en vue de se présenter au passage de l'examen, le seul suivi de la formation ne constitue pas un élément suffisant pour garantir un bon résultat et/ou l'obtention de la certification.

Pour certaines formations certifiantes (ex : ITIL, Prince2, DPO, …), le passage de l'examen de certification est inclus et réalisé en fin de formation. Les candidats sont alors préparés par le formateur au passage de l'examen tout au long de la formation.

Moyens de suivi d'exécution et appréciation des résultats


Feuille de présence, émargée par demi-journée par chaque stagiaire et le formateur.

Evaluation qualitative de fin de formation, qui est ensuite analysée par l'équipe pédagogique ENI.

Attestation de fin de formation, remise au stagiaire en main propre ou par courrier électronique.

Qualification du formateur


La formation est animée par un professionnel de l'informatique et de la pédagogie, dont les compétences techniques, professionnelles et pédagogiques ont été validées par des certifications et/ou testées et approuvées par les éditeurs et/ou notre équipe pédagogique. Il est en veille technologique permanente et possède plusieurs années d'expérience sur les produits, technologies et méthodes enseignés. Il est présent auprès des stagiaires pendant toute la durée de la formation.