Tous les indices trouvés, à savoir la fragmentation des tables et fichiers de base de données, ainsi que la mauvaise densité de page, m’ont conduit à identifier trois aspects qu’il m’a fallu résoudre afin de régler le problème des performances de ma base de données. Premièrement, la table la plus
Résolution des problèmes
volumineuse et la plus utilisée avait besoin d’un index afin de gérer une contrainte de clé étrangère.
Ce problème spécifique n’était pas réellement dû à la fragmentation, mais plutôt aux analyses de la table avec clé étrangère de 2,5 Go au cours des mises à jour de la table avec clé primaire. Les analyses provoquaient tellement d’E/S qu’il était impossible de dire s’il existait d’autres problèmes de disque. L’ajout de l’index a raccourci de manière spectaculaire les délais de mise à jour et diminué les E/S d’environ 80 pour cent pendant les mises à jour. Pour résoudre les deux problèmes restants, j’ai écrit la procédure stockée uspDefragTables, que nous allons examiner en détail un peu plus loin. Le deuxième problème identifié était le fait que la table était un segment de mémoire. Autrement dit, ses données sont stockées dans l’ordre de leur insertion. Cette condition n’était en elle-même pas préjudiciable.
Les pages de la table n’étaient que légèrement fragmentées car elle recevait environ 75 à 80 pour cent de toutes les insertions exécutées sur l’ensemble des tables de la base de données, ce qui avait pour effet de maintenir ensemble les extensions. Toutefois, ayez à l’esprit que les valeurs de fragmentation logique et d’extension dans DBCC SHOWCONTIG ne s’appliquent pas à un segment de mémoire. Par conséquent, un segment de mémoire avec une valeur de fragmentation de 0 pour cent peut malgré tout être mal organisé par rapport à la manière dont une application demande les données. En fait, l’organisation même des données provoquait les effets similaires à une fragmentation sur l’extraction des données. La table la plus volumineuse contient des informations détaillées sur différents sujets pour les utilisateurs de l’application et la structure de segment de mémoire de la table force les données détaillées de plusieurs utilisateurs à partager la même page. Le résultat est que la récupération de toutes les données pour un utilisateur (ce qui peut se produire des dizaines de fois en l’espace de quelques minutes) force SQL Server à parcourir la table et à lire quelques lignes de chacune des dizaines de pages par utilisateur.
Non seulement il en résulte plus d’E/S, mais vous avez pratiquement l’assurance que les extensions contenant ces pages ne seront pas adjacentes. Par ailleurs, comme la table est sujette à des milliers d’insertions par minute, chaque extension conserve vraisemblablement uniquement un petit nombre de lignes pour chaque utilisateur. Le troisième problème, qui rend l’organisation des données encore moins performante, est le fait que DBCC SHOWCONTIG indiquait une densité de page inférieure à 50 pour cent. Cela signifiait que cette table utilisait plus de deux fois le nombre de pages nécessaires pour stocker les données.
Trop de pages à moitié vides et dispersées dans tout le fichier de base de données constituent la condition idéale pour des performances extrêmement médiocres. La procédure stockée uspDefragTables illustrée sur le listing 2 permet de résoudre les problèmes d’organisation des données et de densité de page.
Téléchargez cette ressource
Mac en entreprise : le levier d’un poste de travail moderne
Ce livre blanc répond aux 9 questions clés des entreprises sur l’intégration du Mac : sécurité, compatibilité, gestion, productivité, coûts, attractivité talents, RSE et IA, et l’accompagnement sur mesure proposé par inmac wstore.
Les articles les plus consultés
- Afficher les icônes cachées dans la barre de notification
- N° 2 : Il faut supporter des langues multiples dans SharePoint Portal Server
- Chiffrements symétrique vs asymétrique
- Activer la mise en veille prolongée dans Windows 10
- Partager vos images, vidéos, musique et imprimante avec le Groupe résidentiel
Les plus consultés sur iTPro.fr
- L’intelligence de « l’innovation actionnable » pour anticiper les disruptions plutôt que les subir
- Stratégie de cyber résilience : la France en avance sur la prise de conscience mais en retard sur les moyens
- Pourquoi Shopify Plus s’impose dans la transformation du e-commerce B2B
- Cybersécurité 2026 : Deepfakes, IA agentique et déficit de préparation
Articles les + lus
Confiance et curiosité : les clés pour entrer (et grandir) en tant que femme dans la tech
Portails développeurs internes : accélérer l’innovation sans alourdir les budgets
Pourquoi Shopify Plus s’impose dans la transformation du e-commerce B2B
Quand l’innovation échappe à ses créateurs: Comment éviter l’effet Frankenstein à l’ère de l’IA
Alliée ou menace ? Comment l’IA redessine le paysage cyber
À la une de la chaîne Tech
- Confiance et curiosité : les clés pour entrer (et grandir) en tant que femme dans la tech
- Portails développeurs internes : accélérer l’innovation sans alourdir les budgets
- Pourquoi Shopify Plus s’impose dans la transformation du e-commerce B2B
- Quand l’innovation échappe à ses créateurs: Comment éviter l’effet Frankenstein à l’ère de l’IA
- Alliée ou menace ? Comment l’IA redessine le paysage cyber
