Amazon RDS - Tâches MySQL DBA
Comme pour toutes les autres bases de données, Amazon RDS MYSQL a également besoin de tâches DBA pour affiner la base de données et effectuer des vérifications périodiques de l'état de santé, etc. être effectuée par rapport à l'installation sur site de MySQL. Vous trouverez ci-dessous une liste des tâches DBA courantes pouvant être effectuées dans la base de données AWS RDS MySQL et leurs descriptions.
Le fichier journal des erreurs MySQL (mysql-error.log) peut être affiché à l'aide de la console Amazon RDS ou en récupérant le journal à l'aide de l'interface de ligne de commande Amazon RDS. mysql-error.log est vidé toutes les 5 minutes et son contenu est ajouté à mysql-error-running.log. Le fichier mysql-error-running.log est ensuite tourné toutes les heures et les fichiers horaires générés au cours des dernières 24 heures sont conservés.
Utilisation de la console RDS
Vous trouverez ci-dessous des liens vers deux fichiers journaux décrits ci-dessus.
Utilisation de la CLI
À l'aide de la CLI, les fichiers journaux sont publiés dans CloudWatch Logs en tant qu'objet JSON.
aws rds modify-db-instance \
--db-instance-identifier mydbinstance \
--cloudwatch-logs-export-configuration '{"EnableLogTypes":["audit","error","general","slowquery"]}' \
--apply-immediately
Parfois, l'administrateur de base de données a besoin de tuer une longue session ou une requête qui ne donne pas le résultat assez rapidement. Cette tâche DBA est effectuée en recherchant d'abord l'ID de processus de la requête, puis en utilisant une fonction RDS pour arrêter la requête. Les commandes ci-dessous sont des exemples.
# get the ID
Select * from INFORMATION_SCHEMA.PROCESSLIST
#Apply the Kill Function
CALL mysql.rds_kill(processID);
Nous pouvons améliorer le temps de récupération après un crash en définissant un paramètre DB appelé innodb_file_per_table. Nous pouvons trouver ce paramètre dans la console RDS comme indiqué ci-dessous.
Ensuite, nous pouvons rechercher le nom du paramètre comme indiqué ci-dessous.
Amazon RDS définit la valeur par défaut du paramètre innodb_file_per_table sur 1, ce qui vous permet de supprimer des tables InnoDB individuelles et de récupérer le stockage utilisé par ces tables pour l'instance de base de données. Cela accélère le temps de récupération après le crash.
L'arrêt d'une base de données, son redémarrage ou la création d'instantanés, etc. peuvent être effectués facilement via la console RDS, comme indiqué dans le diagramme ci-dessous.