L'outil de recommandation Cloud SQL pour nombre élevé de tables ouvertes vous aide à détecter les instances dont le nombre de tables ouvertes simultanément est égal à la valeur de table_open_cache
. Il vous fournit ensuite des recommandations sur l'optimisation de ces instances pour améliorer les performances.
Cette page décrit le fonctionnement de l'outil de recommandation pour nombre de tables ouvertes et son utilisation.
Fonctionnement
MySQL est multithread, et les clients peuvent simultanément émettre une requête sur la même table à partir de plusieurs threads. Ainsi, MySQL peut avoir des tables ouvertes indépendamment pour chaque session.
Le nombre de tables ouvertes simultanément est géré par table_open_cache
.
Si le cache est plein et que d'autres tables sont ouvertes, MySQL ferme la table utilisée le moins récemment. Si toutes les tables du cache sont actuellement utilisées, MySQL étend temporairement le cache et ferme les tables dès qu'elles ne sont plus utilisées.
Si le nombre de tables ouvertes dépasse la valeur table_open_cache
, les performances de la base de données peuvent être négatives lors d'une charge de travail élevée. En effet, davantage de threads sont créés et les gestionnaires de tables doivent ouvrir et fermer les tables plus fréquemment.
L'outil de recommandation pour nombre élevé de tables ouvertes de Cloud SQL analyse quotidiennement les métriques relatives au nombre de tables ouvertes sur une instance MySQL Cloud SQL. Si le nombre de tables ouvertes augmente d'une unité toutes les deux secondes, ou à un rythme plus rapide, au cours des dernières 24 heures, et que le nombre de tables ouvertes est supérieur ou égal à la valeur table_open_cache
, l'outil de recommandation vous conseille d'ajuster l'option table_open_cache
.
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.
Lister les recommandations sur les performances des instances
Vous pouvez répertorier les recommandations de performances de l'instance à l'aide de l'instance Google Cloud, de gcloud CLI
ou de l'API Recommender.
Les recommandations d'amélioration des performances ne s'affichent que si des instances sont sur le point d'atteindre les limites du 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 sur la bannière d'augmentation des recommandations de cache d'ouverture de table.
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 Augmenter le cache ouvert de la table.
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_OPEN_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 qui ont un grand nombre de tables ouvertes, 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 qui comportent un grand nombre de tables ouvertes à 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_OPEN_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 les instances qui ont un grand nombre de tables ouvertes à 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.MySqlHighNumberOfOpenTables/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 ouvertes est égal à la valeur de l'option table_open_cache .Sous-type : MYSQL_HIGH_NUMBER_OF_OPEN_TABLES
| Améliorez les performances des instances Cloud SQL en réduisant le nombre de tables ouvertes. Sous-type : MYSQL_HIGH_NUMBER_OF_OPEN_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
Pour optimiser les performances de votre instance, effectuez l'une des opérations suivantes :
Augmentez de 500 la valeur de
table_open_cache
, jusqu'à ce que la recommandation disparaisse. La recommandation est mise à jour quotidiennement. Par conséquent, après avoir augmenté la valeur detable_open_cache
, attendez 24 heures avant de vérifier à nouveau si elle est présente.Si la valeur de
open_tables
est supérieure à celle detable_open_cache
, augmentez la valeur detable_open_cache
à la valeur deopen_tables
.Pour en savoir plus sur la mise à jour d'une option de base de données, consultez la page Configurer des options de base de données.
Étapes suivantes
- Gérer un nombre élevé de tables
- 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.