Amazon RDS: funciones de MS SQL

El servidor Microsoft SQL es una base de datos relacional prominente en la industria. AWS RDS admite varias versiones del servidor MS SQL. A continuación, lista de versiones y ediciones compatibles. Todas estas versiones admiten restauraciones puntuales y copias de seguridad automáticas o manuales. Las instancias de base de datos que ejecutan SQL Server se pueden usar dentro de una VPC. También puede utilizar SSL para conectarse a una instancia de base de datos que ejecute SQL Server. Amazon RDS actualmente admite implementaciones Multi-AZ para SQL Server utilizando SQL Server Mirroring como una solución de conmutación por error de alta disponibilidad.

AWS RDS pone a disposición las principales versiones del servidor MS SQL desde 2008 en adelante. Los detalles de estas versiones son los siguientes.

  • SQL Server 2017 RTM

  • SQL Server 2016 SP1

  • SQL Server 2014 SP2

  • SQL Server 2012 SP4

  • SQL Server 2008 R2 SP3

A continuación, se muestra un ejemplo de cómo obtener las versiones de DB Engine compatibles con la API de AWS en un programa de Python SDK.

import boto3

client = boto3.client('rds')

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

print(response)

Al ejecutar el programa anterior, obtenemos el siguiente resultado:

{
   "ResponseMetadata": {
      "RetryAttempts": 0,
      "HTTPStatusCode": 200,
      "RequestId": "186a9d70-7580-4207-8727-4d29aebb5213",
      "HTTPHeaders": {
         "x-amzn-requestid": "186a9d70-7580-4207-8727-4d29aebb5213",
         "date": "Fri, 14 Sep 2018 05:39:11 GMT",
         "content-length": "1066",
         "content-type": "text/xml"
      }
   },
   "u'DBEngineVersions'": [
      {
         "u'Engine'": "sqlserver-ee",
         "u'DBParameterGroupFamily'": "sqlserver-ee-14.0",
         "u'SupportsLogExportsToCloudwatchLogs'": false,
         "u'SupportsReadReplica'": true,
         "u'DBEngineDescription'": "MicrosoftSQLServerEnterpriseEdition",
         "u'EngineVersion'": "14.00.3035.2.v1",
         "u'DBEngineVersionDescription'": "SQL Server 2017 14.00.3035.2.v1",
         "u'ValidUpgradeTarget'": []
      }
   ]
}

La licencia de software para la instancia de base de datos RDS está incluida en el precio del uso del servidor MS SQL. El usuario no necesita traer ninguna licencia. Además, el precio incluye licencia de software, recursos de hardware y funciones de administración de AWS RDS.

A continuación se muestran las ediciones de servidor de MS SQL que están disponibles en las ediciones de MS SQL Server.

  • Enterprise

  • Standard

  • Web

  • Express

A diferencia de Oracle, no existe ningún requisito de licencia adicional para la implementación de Multi AZ. Microsoft Server utiliza la creación de reflejo de la base de datos del servidor SQL para dicha implementación.

Para las instancias canceladas debido a problemas de licencia, AWS mantiene instantáneas de base de datos desde las cuales se puede restaurar la base de datos, cuando se resuelve el problema de licencia.

El motor de base de datos del servidor MS SQL utiliza una seguridad basada en roles.

El nombre de usuario maestro que se usa al crear una instancia de base de datos es un inicio de sesión de autenticación de SQL Server que es miembro de las funciones de servidor fijas processadmin, public y setupadmin. permisos de nivel de base de datos excepto aquellos que se utilizan para copias de seguridad. Amazon RDS administra las copias de seguridad del usuario.

Hay bastantes funciones que no son compatibles con AWS RDS para MS SQL Server. Algunos de ellos se enumeran a continuación. Esto es importante para un escenario en el que la base de datos local se lleva a la nube, la disponibilidad de estas funciones debe evaluarse cuidadosamente.

  • Siempre encendido

  • Copia de seguridad en Microsoft Azure Blob Storage

  • Extensión del grupo de búfer

  • Características BULK INSERT y OPENROWSET (BULK ...)

  • Servicios de calidad de datos

  • Consultas distribuidas (es decir, servidores vinculados)

  • Coordinador de transacciones de distribución (MSDTC)

  • Tablas de archivos

  • Soporte de FILESTREAM

  • Recopilador de datos de rendimiento

  • Gestión basada en políticas

  • Auditoría de SQL Server

  • Activadores de nivel de servidor

  • Puntos finales T-SQL (todas las operaciones que utilizan CREATE ENDPOINT no están disponibles)