Amazon RDS - Fonctionnalités MariaDB

MariaDB est une base de données relationnelle open source populaire qui est disponible dans les services amazon RDS avec ses fonctionnalités d'édition communautaire. Presque toutes les fonctionnalités de MariaDB peuvent être exploitées dans la plate-forme RDS. Vous trouverez ci-dessous une brève description des principales fonctionnalités de MariaDB dans la plate-forme RDS.

Les versions 10.0, 10.1, 10.2 sont les principales versions prises en charge par la plate-forme RDS. Si aucune version n'est mentionnée lors de la création de la base de données, elle utilise par défaut la version la plus récente à ce moment-là. Vous trouverez ci-dessous un exemple de la façon d'obtenir toutes les versions de DB Engine prises en charge à l'aide de l'API AWS dans un programme SDK python.

import boto3

client = boto3.client('rds')

response = client.describe_db_engine_versions(
    DBParameterGroupFamily='',
    DefaultOnly=True,
    Engine='mariadb',
    EngineVersion='',
    ListSupportedCharacterSets=False, #True,
)

print(response)

Lorsque nous exécutons le programme ci-dessus, nous obtenons la sortie suivante -

{ 
   "ResponseMetadata": { 
      "RetryAttempts": 0,
      "HTTPStatusCode": 200,
      "RequestId": "16179fbd-9d07-425b-9b86-cc61359ce7b4",
      "HTTPHeaders": { 
         "x-amzn-requestid": "16179fbd-9d07-425b-9b86-cc61359ce7b4",
         "date": "Fri, 14 Sep 2018 06:45:52 GMT",
         "content-length": "1658",
         "content-type": "text/xml"
      }
   },
   "u'DBEngineVersions'": [ 
      { 
         "u'Engine'": "mariadb",
         "u'DBParameterGroupFamily'": "mariadb10.2",
         "u'SupportsLogExportsToCloudwatchLogs'": true,
         "u'SupportsReadReplica'": true,
         "u'DBEngineDescription'": "MariaDb Community Edition",
         "u'EngineVersion'": "10.2.12",
         "u'DBEngineVersionDescription'": "mariadb 10.2.12",
         "u'ExportableLogTypes'": [ 
            "audit",
            "error",
            "general",
            "slowquery"
         ],
         "u'ValidUpgradeTarget'": [ 
            { 
               "u'Engine'": "mariadb",
               "u'IsMajorVersionUpgrade'": false,
               "u'AutoUpgrade'": false,
               "u'Description'": "MariaDB 10.2.15",
               "u'EngineVersion'": "10.2.15"
            }
         ]
      }
   ]
}

La sécurité de RDS MariaDB est gérée à trois niveaux.

Utilisation d'IAM

Dans cette approche, l'utilisateur IAM doit disposer de stratégies et d'autorisations appropriées. L'octroi de ces autorisations est décidé par le titulaire du compte ou le super utilisateur qui accorde ces autorisations.

Utiliser VPC

Vous utilisez un groupe de sécurité VPC ou un groupe de sécurité DB pour décider quelles instances EC2 peuvent ouvrir des connexions au point de terminaison et au port d'une instance de base de données. Ces connexions peuvent également être établies à l'aide de SSL.

Utilisation de l'authentification de base de données IAM

Dans cette approche, vous utilisez un rôle IAM et un jeton d'authentification. Le jeton d'authentification génère une valeur unique qui est pertinente pour le rôle IAM utilisé dans le processus d'accès. Ici, le même ensemble d'informations d'identification est utilisé pour la base de données ainsi que pour d'autres ressources aws, comme EC2 et S3, etc.

Le préchauffage du cache peut améliorer les performances de votre instance de base de données MariaDB en enregistrant l'état actuel du pool de mémoire tampon lorsque l'instance de base de données est arrêtée, puis en rechargeant le pool de mémoire tampon à partir des informations enregistrées au démarrage de l'instance de base de données. Cette approche évite la nécessité pour le pool de tampons de "se réchauffer" à partir de l'utilisation normale de la base de données et précharge le pool de tampons avec les pages pour les requêtes courantes connues.

Le réchauffement du cache offre principalement un avantage en termes de performances pour les instances de base de données qui utilisent le stockage standard.

Vous pouvez créer un événement pour vider le pool de mémoire tampon automatiquement et à intervalles réguliers. Par exemple, l'instruction suivante crée un événement nommé period_buffer_pool_dump qui vide le pool de mémoire tampon toutes les heures.

CREATE EVENT periodic_buffer_pool_dump 
   ON SCHEDULE EVERY 1 HOUR 
   DO CALL mysql.rds_innodb_buffer_pool_dump_now();