Les traductions sont fournies par des outils de traduction automatique. En cas de conflit entre le contenu d'une traduction et celui de la version originale en anglais, la version anglaise prévaudra.
Problèmes connus et limites d'Amazon RDS for My SQL
Les problèmes et limites connus liés à l'utilisation d'Amazon RDS for My SQL sont les suivants.
Rubriques
- Mot réservé InnoDB
- Comportement d'Amazon RDS for My en cas de saturation du stockage SQL
- Taille de pool de mémoires tampons InnoDB incohérente
- L'optimisation de la fusion d'index renvoie des résultats incorrects
- Mes exceptions de SQL paramètres pour les RDS instances de base de données Amazon
- Mes limites de taille de SQL fichier sur Amazon RDS
- Le plugin My SQL Keyring n'est pas pris en charge
- Ports personnalisés
- Limites de mes procédures SQL stockées
- GTIDréplication basée sur une instance source externe
- Mon plugin d'authentification SQL par défaut
- Remplacer innodb_buffer_pool_size
- Mise à niveau de My SQL 5.7 vers My SQL 8.4
- Compression de page InnoDB
Mot réservé InnoDB
InnoDB
est un mot réservé à RDS for MySQL. Vous ne pouvez pas utiliser ce nom pour une base de SQL données Ma base de données.
Comportement d'Amazon RDS for My en cas de saturation du stockage SQL
Lorsque le stockage d'une instance My SQL DB est saturé, il peut y avoir des incohérences dans les métadonnées, des incohérences dans les dictionnaires et des tables orphelines. Pour éviter ces problèmes, Amazon arrête RDS automatiquement une instance de base de données qui atteint storage-full
cet état.
Une instance My SQL DB atteint l'storage-full
état dans les cas suivants :
-
L'instance de base de données possède moins de 20 000 Mio de stockage et le stockage disponible atteint 200 Mio ou moins.
-
L'instance de base de données possède plus de 102 400 Mio de stockage et le stockage disponible atteint 1024 Mio ou moins.
-
L'instance de base de données possède entre 20 000 Mio et 102 400 Mio de stockage et dispose de moins de 1 % du stockage disponible.
Une fois qu'Amazon RDS arrête automatiquement une instance de base de données parce qu'elle a atteint son storage-full
état, vous pouvez toujours la modifier. Pour redémarrer l'instance de base de données, effectuez au moins l'une des opérations suivantes :
-
Modifiez l'instance de base de données pour activer le dimensionnement automatique du stockage.
Pour plus d'informations sur le dimensionnement automatique du stockage, consultez Gestion automatique de la capacité avec Amazon RDS Storage AutoScaling.
-
Modifiez l'instance de base de données pour augmenter sa capacité de stockage.
Pour plus d'informations sur l'augmentation de la capacité de stockage, consultez Augmentation de la capacité de stockage d'une instance de base de données.
Après avoir effectué l'une de ces modifications, l'instance de base de données est automatiquement redémarrée. Pour plus d'informations sur la modification d'une instance de base de données , consultez Modification d'une RDS instance de base de données Amazon.
Taille de pool de mémoires tampons InnoDB incohérente
Pour My SQL 5.7, il existe actuellement un bogue dans la façon dont la taille du pool de tampons InnoDB est gérée. Mon SQL 5.7 peut ajuster la valeur du innodb_buffer_pool_size
paramètre à une valeur élevée, ce qui peut entraîner une trop grande taille du pool de tampons InnoDB et une utilisation excessive de mémoire. Cet effet peut entraîner l'arrêt du moteur Ma SQL base de données ou l'empêcher de démarrer. Ce problème est plus courant pour des classes d'instance de base de données dont l'espace mémoire disponible est moindre.
Pour résoudre ce problème, définissez la valeur du paramètre innodb_buffer_pool_size
sur un multiple du produit des valeurs de paramètre innodb_buffer_pool_instances
et innodb_buffer_pool_chunk_size
. Par exemple, vous pouvez définir la valeur de paramètre innodb_buffer_pool_size
sur un multiple de huit fois le produit des valeurs de paramètre innodb_buffer_pool_instances
et innodb_buffer_pool_chunk_size
, comme illustré dans l'exemple suivant.
innodb_buffer_pool_chunk_size = 536870912 innodb_buffer_pool_instances = 4 innodb_buffer_pool_size = (536870912 * 4) * 8 = 17179869184
Pour plus de détails sur ce bogue de My SQL 5.7, consultez le https://bugs.mysql.comfichier /bug.php ? id=79379
L'optimisation de la fusion d'index renvoie des résultats incorrects
Les requêtes qui utilisent l'optimisation de la fusion d'index peuvent renvoyer des résultats incorrects en raison d'un bogue dans l'optimiseur de SQL requêtes My SQL 5.5.37. Lorsque vous exécutez une requête sur une table avec plusieurs index, l'optimiseur analyse les plages de lignes selon les multiples index, mais il ne fusionne pas correctement les résultats. Pour plus d'informations sur le bogue de l'optimiseur de requêtes, consultez http://bugs.mysql.com/bug.php?id=72745
Par exemple, imaginons une requête sur une table avec deux index où les arguments de la recherche font référence aux colonnes indexées.
SELECT * FROM table1 WHERE indexed_col1 = 'value1' AND indexed_col2 = 'value2';
Dans ce cas, le moteur de recherche analysera les deux index. Cependant, à cause du bogue, les résultats fusionnés sont incorrects.
Pour résoudre ce problème, vous pouvez procéder de l'une des manières suivantes :
Définissez le
optimizer_switch
paramètre surindex_merge=off
dans le groupe de paramètres de base de données de votre instance My SQL DB. Pour plus d'informations sur la définition des paramètres d'un groupe de paramètres DB, consultez Groupes de paramètres pour Amazon RDS.-
Mettez à niveau votre instance My SQL DB vers My SQL version 5.7 ou 8.0. Pour de plus amples informations, veuillez consulter Mises à niveau du moteur RDS for My SQL DB.
-
Si vous ne pouvez pas mettre à niveau votre instance ou modifier le paramètre
optimizer_switch
, vous pouvez contourner le bogue en identifiant explicitement un index pour la requête, par exemple :SELECT * FROM table1 USE INDEX covering_index WHERE indexed_col1 = 'value1' AND indexed_col2 = 'value2';
Pour plus d'informations, consultez la section Optimisation de la fusion d'index
Mes exceptions de SQL paramètres pour les RDS instances de base de données Amazon
Certains SQL paramètres My nécessitent des considérations particulières lorsqu'ils sont utilisés avec une RDS instance de base de données Amazon.
lower_case_table_names
Amazon RDS utilisant un système de fichiers sensible aux majuscules et minuscules, il n'est pas possible de définir la valeur lower_case_table_names
du paramètre du serveur sur 2 (noms stockés tels quels mais comparés en minuscules). Les valeurs prises en charge pour les instances Amazon RDS for My SQL DB sont les suivantes :
-
0 (les noms sont stockés tels quels et les comparaisons distinguent les majuscules et minuscules) est pris en charge RDS pour toutes les SQL versions de My.
-
1 (les noms sont stockés en minuscules et les comparaisons ne font pas la distinction entre majuscules et minuscules) est pris en charge RDS pour My SQL version 5.7, version 8.0.28 et versions 8.0 supérieures, et pour la version 8.4.
Définissez le paramètre lower_case_table_names
dans un groupe de paramètres de base de données personnalisé avant de créer une instance de base de données. Ensuite, spécifiez le groupe de paramètres de base de données personnalisé lorsque vous créez l'instance de base de données.
Lorsqu'un groupe de paramètres est associé à une instance My SQL DB dont la version est inférieure à 8.0, nous vous recommandons d'éviter de modifier le lower_case_table_names
paramètre dans le groupe de paramètres. Sa modification peut entraîner des incohérences entre les sauvegardes de point-in-time restauration et la lecture des instances de base de données répliquées.
Lorsqu'un groupe de paramètres est associé à une instance My SQL DB version 8.0 ou 8.4, vous ne pouvez pas modifier le lower_case_table_names
paramètre dans le groupe de paramètres.
Les réplicas en lecture doivent toujours utiliser la même valeur de paramètre lower_case_table_names
que l'instance de base de données source.
long_query_time
Vous pouvez définir le long_query_time
paramètre sur une valeur à virgule flottante afin de pouvoir enregistrer les requêtes lentes dans le journal My SQL slow query log avec une résolution de l'ordre de la microseconde. Vous pouvez définir une valeur telle que 0,1 seconde, ce qui correspondrait à 100 millisecondes, pour aider lors du débogage de transactions lentes qui durent moins d'une seconde.
Mes limites de taille de SQL fichier sur Amazon RDS
Pour les instances de base de données My SQL versions 8.0 et supérieures, la limite de stockage maximale allouée limite la taille d'une table à une taille maximale de 16 To lors de l'utilisation des tablespaces InnoDB. file-per-table Cette limite restreint également l'espace de table du système à une taille maximum de 16 To. Les file-per-table tablespaces InnoDB (avec des tables chacune dans leur propre tablespace) sont définis par défaut pour les instances My DB. SQL
Note
Certaines instances de bases de données existantes ont une limite inférieure. Par exemple, les instances My SQL DB créées avant avril 2014 ont une limite de taille de fichier et de table de 2 To. Cette limite de taille de fichier de 2 To s'applique également aux instances de bases de données ou aux réplicas en lecture créés à partir d'instantanés de bases de données pris avant avril 2014, quel que soit le moment de la création de l'instance de base de données.
L'utilisation des file-per-table tablespaces InnoDB présente des avantages et des inconvénients, en fonction de votre application. Pour déterminer la meilleure approche pour votre application, consultez les File-per-table espaces de table
Il est déconseillé d'autoriser les tables à dépasser la taille maximale de fichier. En général, une meilleure pratique consiste à partitionner les données en tables plus petites, ce qui peut améliorer la performance et les temps de récupération.
Vous pouvez utiliser l'option de partitionnement pour diviser une grande table en tables plus petites. Le partitionnement répartit des portions de votre grande table en fichiers distincts basés sur des règles que vous spécifiez. Par exemple, si vous stockez des transactions par date, vous pouvez créer des règles de partitionnement qui répartissent des transactions plus anciennes en fichiers distincts en utilisant le partitionnement. Ensuite, vous pouvez archiver régulièrement les données de transaction historiques qui n'ont pas besoin d'être rapidement utilisables par votre application. Pour plus d'informations, consultez la section Partitionnement
Comme aucune table ou vue système ne fournit la taille de toutes les tables et de l'espace de table système InnoDB, vous devez interroger plusieurs tables pour déterminer la taille des espaces de table.
Pour déterminer la taille de l'espace de table système InnoDB et de l'espace de table du dictionnaire de données
-
Utilisez la SQL commande suivante pour déterminer si certains de vos espaces disque logiques sont trop grands et sont susceptibles d'être partitionnés.
Note
Le tablespace du dictionnaire de données est spécifique à My SQL 8.0 et aux versions supérieures.
select FILE_NAME,TABLESPACE_NAME, ROUND(((TOTAL_EXTENTS*EXTENT_SIZE) /1024/1024/1024), 2) as "File Size (GB)" from information_schema.FILES where tablespace_name in ('mysql','innodb_system');
Pour déterminer la taille des tables utilisateur InnoDB en dehors de l'espace de table du système InnoDB (pour les versions My 5.7) SQL
-
Utilisez la SQL commande suivante pour déterminer si l'une de vos tables est trop grande et peut être partitionnée.
SELECT SPACE,NAME,ROUND((ALLOCATED_SIZE/1024/1024/1024), 2) as "Tablespace Size (GB)" FROM information_schema.INNODB_SYS_TABLESPACES ORDER BY 3 DESC;
Pour déterminer la taille des tables utilisateur InnoDB en dehors de l'espace de table du système InnoDB (pour My 8.0 et versions supérieures) SQL
-
Utilisez la SQL commande suivante pour déterminer si l'une de vos tables est trop grande et peut être partitionnée.
SELECT SPACE,NAME,ROUND((ALLOCATED_SIZE/1024/1024/1024), 2) as "Tablespace Size (GB)" FROM information_schema.INNODB_TABLESPACES ORDER BY 3 DESC;
Pour déterminer la taille des tables utilisateur non-InnoDB
-
Utilisez la SQL commande suivante pour déterminer si l'une de vos tables d'utilisateurs autres que celles d'InnoDB est trop grande.
SELECT TABLE_SCHEMA, TABLE_NAME, round(((DATA_LENGTH + INDEX_LENGTH+DATA_FREE) / 1024 / 1024/ 1024), 2) As "Approximate size (GB)" FROM information_schema.TABLES WHERE TABLE_SCHEMA NOT IN ('mysql', 'information_schema', 'performance_schema') and ENGINE<>'InnoDB';
Pour activer les tablespaces InnoDB file-per-table
-
Définissez le paramètre innodb_file_per_table sur
1
dans le groupe de paramètres pour l'instance de base de données.
Pour désactiver les tablespaces InnoDB file-per-table
-
Définissez le paramètre innodb_file_per_table sur
0
dans le groupe de paramètres pour l'instance de base de données.
Pour plus d'informations sur la mise à jour d'un groupe de paramètres, consultez Groupes de paramètres pour Amazon RDS.
Lorsque vous avez activé ou désactivé les file-per-table tablespaces InnoDB, vous pouvez émettre une ALTER
TABLE
commande pour déplacer une table du tablespace global vers son propre tablespace, ou de son propre tablespace vers le tablespace global, comme indiqué dans l'exemple suivant :
ALTER TABLE table_name TABLESPACE=innodb_file_per_table;
Le plugin My SQL Keyring n'est pas pris en charge
Actuellement, Amazon RDS for My SQL ne prend pas en charge le plug-in My SQL keyring_aws
Amazon Web Services Keyring.
Ports personnalisés
Amazon RDS bloque les connexions au port personnalisé 33060 pour le SQL moteur My. Choisissez un autre port pour votre SQL moteur My Engine.
Limites de mes procédures SQL stockées
Les mysql.rds_kill procédures mysql.rds_kill_query stockées ne peuvent pas mettre fin aux sessions ou aux requêtes détenues par Mes SQL utilisateurs dont le nom d'utilisateur comporte plus de 16 caractères, comme suit RDS pour Mes SQL versions :
-
8.0.32 et versions 8 antérieures
-
5.7.41 et versions 5.7 antérieures
GTIDréplication basée sur une instance source externe
Amazon RDS prend en charge la réplication basée sur des identifiants de transaction globaux (GTIDs) depuis une SQL instance externe My vers une instance Amazon RDS for My SQL DB qui nécessite de définir GTID _ PURGED lors de la configuration. Toutefois, seules RDS les versions SQL 8.0.37 et supérieures de My prennent en charge cette fonctionnalité.
Mon plugin d'authentification SQL par défaut
RDSpour My SQL version 8.0.34 et versions 8.0 supérieures, utilisez le mysql_native_password
plugin. Vous ne pouvez pas modifier le paramètre default_authentication_plugin
.
RDSpour My SQL version 8.4 et versions supérieures, utilisez le caching_sha2_password
plugin comme plugin d'authentification par défaut. Vous pouvez modifier le plugin d'authentification par défaut pour My SQL 8.4. Le mysql_native_password
plugin fonctionne toujours avec My SQL 8.4, mais le support de ce plugin prend fin avec My SQL 8.4. Pour modifier le plug-in d'authentification par défaut, créez un groupe de paramètres personnalisé et modifiez la valeur du authentication_policy
paramètre. Pour de plus amples informations, veuillez consulter Groupes de paramètres par défaut et personnalisés.
Remplacer innodb_buffer_pool_size
Dans le cas de classes d'instance de base de données de petite ou de petite taille, la valeur par défaut du innodb_buffer_pool_size
paramètre peut être différente de la valeur renvoyée en exécutant la commande suivante :
mysql> SELECT @@innodb_buffer_pool_size;
Cette différence peut se produire lorsqu'Amazon RDS doit remplacer la valeur par défaut dans le cadre de la gestion des classes d'instances de base de données. Si nécessaire, vous pouvez remplacer la valeur par défaut et la définir sur une valeur prise en charge par votre classe d'instance de base de données. Pour déterminer une valeur valide, ajoutez l'utilisation de la mémoire et la mémoire totale disponible sur votre instance de base de données. Pour plus d'informations, consultez la section Types d'RDSinstances Amazon
Si votre instance de base de données ne dispose que de 4 Go de mémoire, vous ne pouvez pas la innodb_buffer_pool_size
définir sur 8 Go, mais vous pouvez peut-être la définir sur 3 Go, en fonction de la quantité de mémoire que vous avez allouée aux autres paramètres.
Si la valeur que vous saisissez est trop élevée, Amazon la RDS réduit aux limites suivantes :
-
Classes d'instances Micro DB : 256 Mo
-
Classes d'instance de base de données db.t4g.micro : 128 Mo
Mise à niveau de My SQL 5.7 vers My SQL 8.4
Vous ne pouvez pas passer directement de My SQL 5.7 à My SQL 8.4. Vous devez d'abord passer de My SQL 5.7 à My SQL 8.0, puis passer de My SQL 8.0 à My SQL 8.4. Pour de plus amples informations, veuillez consulter Mises à niveau de version majeures RDS pour for My SQL.
Compression de page InnoDB
La compression de page InnoDB ne fonctionne pas avec les instances Amazon RDS DB dont la taille de bloc de système de fichiers est de 16 ko, car la taille de bloc du système de fichiers doit être inférieure à la taille de page InnoDB. À compter de février 2024, toutes les instances de base de données nouvellement créées ont une taille de bloc de système de fichiers de 16 ko, ce qui augmente le débit et réduit la IOPS consommation lors des vidanges de pages.