L'outil de recommandation pour nombre élevé de tables Cloud SQL vous aide à détecter les instances dont le nombre de tables est trop élevé et proche de la limite du contrat de niveau de service. Il vous fournit ensuite des recommandations sur la façon d'optimiser ces instances et d'améliorer leurs performances.
Cette page décrit le fonctionnement de l'outil de recommandation pour nombre élevé de tables, et comment vous pouvez l'utiliser.
Fonctionnement
Si vous avez 50 000 tables de base de données ou plus sur une seule instance, celle-ci risque de ne plus répondre ou d'être incapable d'effectuer des opérations de maintenance. Elle n'est, dès lors, plus couverte par le contrat de niveau de service.
L'outil de recommandation pour nombre élevé de tables Cloud SQL analyse les métriques pour le nombre de tables sur une instance MySQL Cloud SQL. Si le nombre de tables est supérieur ou égal à 80 % de la limite du contrat de niveau de service, soit 50 000 tables, l'instance est considérée comme ayant un nombre élevé de tables.
Tarifs
L'outil de recommandation pour nombre élevé de tables Cloud SQL est inclus dans le niveau de tarification standard de l'outil de recommandation.
Avant de commencer
Afin de pouvoir afficher les recommandations et les insights, procédez comme suit :
- Pour obtenir les autorisations permettant d'afficher et d'utiliser les insights et les recommandations, assurez-vous de disposer des rôles requis.
Tâches Rôles Afficher les recommandations L'un des rôles suivants : recommender.cloudsqlViewer
oucloudsql.viewer
.Appliquer les recommandations L'un des rôles suivants : recommender.cloudsqlAdmin
,cloudsql.editor
oucloudsql.admin
. -
Enable the Recommender API.
Répertorier les recommandations d'amélioration des performances des instances
Vous pouvez répertorier les recommandations d'amélioration des performances d'instance à l'aide de la console Google Cloud, de gcloud CLI
ou de l'API Recommender.
Les recommandations d'amélioration des performances ne s'affichent que si des instances s'approchent de leurs limites de seuil de performances.
Console
Pour répertorier les recommandations relatives aux performances des instances en utilisant la console Google Cloud, procédez comme suit :
Accédez à la page Instances Cloud SQL.
Cliquez sur Tout afficher dans la bannière de recommandations "Gérer un nombre élevé de tables".
Vous pouvez également procéder comme suit :
Accédez au centre de recommandations. Consultez également la section Premiers pas avec le centre de recommandations.
Dans la fiche Améliorer les performances des instances Cloud SQL, cliquez sur Tout afficher.
Sélectionnez les instances avec la recommandation Gérer un grand nombre de tables.
CLI gcloud
Pour répertorier les recommandations d'amélioration des performances des instances à l'aide de gcloud CLI
, exécutez la commande gcloud recommender recommendations list
comme suit :
gcloud recommender recommendations list \ --project=PROJECT_ID \ --location=LOCATION \ --recommender=google.cloudsql.instance.PerformanceRecommender \ --filter=recommenderSubtype=MYSQL_HIGH_NUMBER_OF_TABLES_BEST_PRACTICE
Remplacez les éléments suivants :
PROJECT_ID
: ID de votre projetLOCATION
: une région, telle queus-central1
API
Pour répertorier les recommandations d'amélioration des performances des instances à l'aide de l'API Recommendations, appelez la méthode recommendations.list
comme suit :
GET https://recommender.googleapis.com/v1beta1/projects/PROJECT-ID/locations/LOCATION/recommenders/google.cloudsql.instance.PerformanceRecommender.MySqlHighNumberOfTablesBestPractice/recommendations
Remplacez les éléments suivants :
PROJECT_ID
: ID de votre projetLOCATION
: une région, telle queus-central1
Si l'outil de recommandation détecte des instances avec un grand nombre de tables, il les répertorie dans une table avec d'autres recommandations de performances. Chaque ligne indique l'ID d'instance, une brève recommandation, le moteur de la base de données, l'emplacement et la date de la dernière actualisation.
Afficher les insights et les recommandations détaillées
Vous pouvez afficher des insights et des recommandations détaillées sur les instances comportant un grand nombre de tables à l'aide de la console Google Cloud, de gcloud CLI
ou de l'API Recommender.
Console
Pour afficher des insights et des recommandations détaillées sur les instances proches du seuil de performances à l'aide de la console Google Cloud, cliquez sur le lien de recommandation dans la liste des instances.
CLI gcloud
Pour afficher des insights et des recommandations détaillées sur des instances proches du seuil de performances à l'aide de gcloud CLI
, exécutez la commande gcloud recommender insights list
comme suit :
gcloud recommender insights list \ --project=PROJECT_ID \ --location=LOCATION \ --insight-type=google.cloudsql.instance.PerformanceInsight \ --filter=insightSubtype=MYSQL_HIGH_NUMBER_OF_TABLES
Remplacez les éléments suivants :
PROJECT_ID
: ID de votre projetLOCATION
: une région, telle queus-central1
API
Pour afficher des insights et des recommandations détaillées sur des instances proches du seuil de performances à l'aide de l'API Recommendations, appelez la méthode insights.list
comme suit :
GET https://recommender.googleapis.com/v1beta1/projects/PROJECT-ID/locations/LOCATION/insightTypes/google.cloudsql.instance.PerformanceRecommender.MySqlHighNumberOfTables/insights
Remplacez les éléments suivants :
PROJECT_ID
: ID de votre projetLOCATION
: une région, telle queus-central1
La table suivante répertorie les insights et les recommandations que l'outil de recommandation de Cloud SQL pour le nombre élevé de tables ouvertes génère pour vous aider à améliorer les performances.
Les sous-types sont visibles dans les résultats gcloud CLI
et de l'API.
Insight | Recommandation |
---|---|
Le nombre de tables sur cette instance est supérieur ou égal à 80 % de la limite du contrat de niveau de service, soit 50 000 tables. Sous-type : MYSQL_HIGH_NUMBER_OF_TABLES .
| Améliorez les performances des instances Cloud SQL en réduisant le nombre de tables. Sous-type : MYSQL_HIGH_NUMBER_OF_TABLES_BEST_PRACTICE .
|
Appliquer les recommandations
Étudiez attentivement les recommandations et effectuez l'une des opérations suivantes :
Pour examiner la recommandation, cliquez sur Afficher l'instance. Consultez la section Optimiser les performances de votre instance et suivez les recommandations.
Pour ignorer la recommandation afin qu'elle ne soit plus mise en évidence et apparaisse grisée, cliquez sur Ignorer.
Pour fermer le panneau sans appliquer ni ignorer la recommandation, cliquez sur Annuler.
Optimiser les performances de votre instance
Modifiez votre instance pour faire passer le nombre de processeurs virtuels à au moins 32 cœurs et la taille de la mémoire à au moins 200 Go. Cela fait passer la limite de tables de l'instance de 50 000 à 500 000.
Supprimez les tables inutiles :
DROP TABLE TABLE_NAME;
Remplacez les éléments suivants :
TABLE_NAME
: nom de la table que vous souhaitez supprimer.
Réduisez le nombre de tables par instance en répartissant la base de données sur plusieurs instances afin de maintenir le nombre de tables de chaque instance dans les limites recommandées.
Si vous ne pouvez pas réduire immédiatement le nombre de tables, réduisez la probabilité que votre instance soit affectée par un nombre élevé de tables en définissant l'option
innodb_file_per_table
sur OFF. Pour désactiver la valeur de l'optioninnodb_file_per_table
, consultez la page Configurer une option de base de données. Toutefois, ce paramètre ne rétablit pas la conformité de l'instance au contrat de niveau de service. Consultez les consignes opérationnelles suivantes.Utilisez un espace de table général pour créer des tables ou déplacer des tables existantes vers un espace de table général. Pour en savoir plus, consultez la documentation MySQL sur les espaces de table généraux.
Étapes suivantes
- Augmentez la taille du cache ouvert de la table
- Surveiller la disponibilité des disques
- Identifier les instances Cloud SQL inactives
- Réduire les instances Cloud SQL surprovisionnées
- Découvrez les outils de recommandation Google Cloud.