Migración de la base de datos SQL local a la base de Azure SQL Database
Glaucia Lemos
Posted on February 13, 2020
Parece difícil cuando lees el título. Pero, ¡quiero mostrarles a todos aquí que es mucho más fácil de lo que piensan!
Entenderemos los pasos a seguir y verá que esta migración es extremadamente fácil. Vamos?!
¿Qué es Azure SQL Database?
Antes de realizar la migración en este tutorial, me gustaría explicar un poco sobre lo que sería Azure SQL Database.
Azure SQL Database es una base de datos relacional de uso general que se proporciona como un servicio administrado. A través de este servicio, puede crear una capa de almacenamiento de datos de alto rendimiento y alta disponibilidad para las aplicaciones y soluciones de Azure. Y resulta ser una opción muy interesante ya que nos permite procesar datos relacionales y estructuras no relacionales, como: Gráficos, JSON, XML y espacial.
Además, es un servicio totalmente administrado que ofrece alta disponibilidad, copias de seguridad y otras operaciones de mantenimiento comunes. Microsoft controla todas las revisiones y actualizaciones del código de sistema operativo y SQL. No hace falta administrar la infraestructura subyacente. En resumen: ¡no tiene que administrar la infraestructura subyacente! ¡Y eso ya es una gran ventaja!
Otro punto muy importante sobre las opciones de implementación para Azure SQL Database:
- Base de Datos Única: representa una base de datos aislada totalmente administrada.
- Instancia Administrada: es similar a una instancia totalmente administrada del motor de base de datos de Microsoft SQL Server.
- Grupo Elástico: es una colección de bases de datos únicas con un conjunto compartido de recursos, como la CPU o la memoria.
Las explicaciones aquí se resumen. Pero, si desea conocer más detalles sobre cada opción de implementación disponible, puede encontrar más AQUÍ.
Bueno, vamos a la demo!
¡Primeros Pasos!
En primer lugar, me gustaría hablar con todos ustedes que, en mi caso, preferí crear una Máquina Virtual SQL Server 2017 en Azure.
Vea la máquina virtual Azure SQL Server creada en Azure que se ejecuta en mi máquina local:
Demasiado hermoso, ¿no? ¡Recuerde que también puede crear máquinas virtuales de SQL Server en Azure para Windows y Linux!
Otro punto importante: si tiene SQL Server Management Studio instalado localmente en su máquina, no hay problema. ¡Puedes seguir este tutorial que estará bien!
Bueno, abrí Microsoft SQL Server Management Studio en mi VM y creé, para fines de demostración, una base de datos súper simple y básica. Si lo desea, puede copiar el script:
create database demosqlazuredb
use demosqlazuredb;
create table customer(id int, name varchar(50), contact bigint)
insert into customer values(1, 'Empresa XYZ', 87568844),
(2, 'Empresa Auto Peças', 79957755),
(3, 'Empresa Frutos do Mar', 65753311),
(3, 'Empresa Bebidas Geladas', 33554539)
create table employee(id int, name varchar(50), location varchar(50))
insert into employee values(123, 'Glaucia Lemos', 'Rio de Janeiro'),
(232, 'João Paulo', 'Minas Gerais'),
(398, 'Maria Nunes', 'São Paulo'),
(485, 'Fernando Ricardo', 'Brasília')
create table department(id int, name varchar(50))
insert into department values(1, 'Engenharia'),
(2, 'Inovação'),
(3, 'Financeiro'),
(4, 'Administração')
¡Como puede ver, una base de datos simple que tiene solo 3 tablas y algunas inserciones! Ejecutemos esta consulta en SQL Server Management Studio.
Al final tendremos 3 tablas contenidas en la base de datos: demosqlazuredb.
Ahora haga clic derecho en la base de datos: demosqlazuredb y vaya a: Tasks -> Deploy Database to Microsoft Azure SQL Database:
Después de hacer clic, aparecerá otra ventana pidiendo algunas informaciones importantes. Simplemente haga clic en: Next.
¡Ahora especifiquemos dónde se migrará nuestra base de datos! Para hacer esto, haga clic en: Connect
Después de hacer clic en Connect, aparecerá una nueva ventana para que ingrese sus datos de conexión:
Quizás se esté preguntando, si estoy migrando de las instalaciones a la nube, ¿necesito crear una instancia lógica en la nube para conectarme con esta migración? Si esa pregunta se te pasó por la cabeza, ¡estás pensando correctamente! Ahora, en este punto, necesitamos crear esta instancia lógica en Azure y eso es exactamente lo que vamos a hacer ahora.
Creando SQL Database no Azure
Bueno, minimice SQL Server Management Studio y abra el Portal de Azure.
Conta - Azure for Students ⭐️
Si es estudiante en la universidad, puede crear su cuenta de Azure for Students. Esta cuenta le dará el beneficio de tener un crédito de USD 100.00 para usar los servicios de forma gratuita, sin la necesidad de tener una tarjeta de crédito. Para activar esta cuenta, solo acceda al enlace al costado: AQUÍ
Después de ingresar al Portal de Azure, seguiremos estos pasos:
- Haga clic en el menú -> SQL databases
- Haga clic en: Add
- Complete todos los campos obligatorios: Subscription y Resource Group. Si no tiene uno, simplemente créelo haciendo clic en: Create New. Luego ingrese: Database name.
- Luego deberá crear un Server. Para hacer esto, simplemente haga clic en: Create new. Al hacer clic, aparecerá una ventana en el lateral. Complete todos los campos necesarios e incluya un nombre de usuario y contraseña que no se olvide. Y luego haz clic: Ok
Tip: intente escribirlo en un bloc de notas, ya que necesitaremos esta contraseña e login desués.
- Ahora haga clic en: Compute + storage -> Configure database.
- Al hacer clic, aparecerá otra ventana. Como se trata de una simple demostración de migración, elijamos el plan más básico. Haga clic en: Basic -> Apply.
- Luego haga clic en: Review + Create y finalmente: Create
- Después de terminar, haga clic en: Go to Resource
- Ahora se abrirá el Dashboard del recurso recién creado. Sin embargo, hagamos algo muy importante: ¡configure el firewall! Para hacer esto, vaya a: Overview -> Set server firewall. Se abrirá otra ventana.
- Ahora que estamos en el Firewall Settings, haga clic en: Add client IP, haga clic en: OK (Allow Azure Services ...), incluya en el IP de su máquina y luego haga clic en: Save.
tip: si desea obtener más información sobre las reglas de firewall IP en Azure SQL Server, simplemente vaya a: AQUÍ
- Copie el nombre del servidor. ¡Lo necesitaremos para el próximo paso!
Bueno! ¡Ahora nuestra instancia está correctamente creada y configurada! ¡Ahora, terminemos la migración!
Volviendo a SQL Server Management Studio localmente
Volvamos a la ventana de conexión que detuvimos y haremos la conexión necesaria. E incluya la siguiente información:
- Server name: obtendrá esta información del recurso creado en el paso anterior, haciendo clic en Overview en el Portal de Azure (paso anterior)
- Authentication: cambie a SQL Server Authentication
- Login: creado en el paso anterior
- Password: creada en el paso anterior
Y finalmente, haga clic en: Connect.
tip: login y password del recurso creado en Azure!!!
Tenga en cuenta que podemos cambiar cuánto necesitamos gastar en esa base de datos. También podemos hacer este cambio en esa parte del proceso. ¡Esto dependerá de la cantidad de datos que migrará a la nube! Puede usar la calculadora que está disponible AQUÍ. En nuestro caso, como estamos haciendo una demostración, utilizaremos el plan básico y el tamaño: 2.
Luego haga clic en: Next
Y finalmente haga clic en: Finish
Tan pronto como haga clic en Finish, comenzará la migración que exportará todas las tareas.
Cuando aparece el mensaje: Operation Complete se debe a que la migración se realizó correctamente. Tenga en cuenta que el esquema, las tablas, todo se migró con éxito.
Ahora, puede cerrar la SQL Server Management y veamos qué sucedió, ¡pero ahora en el Portal de Azure!
Abra el Portal de Azure y vaya a: SQL Databases y vea lo que aparecerá:
Aparecerá, precisamente, la base de datos creada lógicamente y a la que migramos (que podría representar la base de datos en producción, por ejemplo). Haga clic en la base de datos recién migrada: (demosqlazuredb)
Ahora haga clic en: Query editor (preview) e incluya la contraseña creada en este recurso. ¡Hagamos algunas consultas SQL en esta base de datos recién migrada!
¡Ahora observe en el gif cómo los datos que anteriormente estaban contenidos localmente en SQL Server Management Studio ahora están disponibles en la nube!
Sensacional! Podemos: importar, exportar, crear procedimientos almacenados y mucho más. 😊
Database Migration Assistant
Podemos migrar los datos de nuestro servidor SQL local utilizando una herramienta llamada: Database Migration Assistant. Esta herramienta fue creada para automatizar la migración de la base de datos a SQL Server desde Microsoft Access, DB2, MYSQL, Oracle y SAP ASE.
Si desea obtener información sobre cómo realizar la migración utilizando el Database Migration Assistant en las bases de datos yo dejo los recursos disponibles:
- SQL Server Migration Assistant para Access
- SQL Server Migration Assistant para DB2
- SQL Server Migration Assistant para MySQL
- SQL Server Migration Assistant para Oracle
- SQL Server Migration Assistant para SAP ASE
Hay un tutorial que le enseña, paso a paso, cómo puede usar esta excelente herramienta que facilita mucho para hacer la migración: AQUÍ.
Próximos Pasos
Hoy aprendimos, con unos pocos pasos, lo fácil que es migrar desde nuestra base local a la nube. ¡Y que podemos hacer uso de otra herramienta que nos ayuda a diseñar y automatizar este proceso de migración en diferentes bases de datos!
Nuevamente, si desea que la parte 2 de este tutorial le enseñe paso a paso cómo realizar la migración con el Asistente de migración de base de datos y también cómo crear una VM SQL Server 2016/2017 en Azure, ¡simplemente déjelo aquí en los comentarios!
Y si desea saber más sobre Azure SQL Database, tenemos numerosos recursos, tutoriales y enlaces que pueden ayudar a todos a realizar estudios y aplicaciones en el mundo real:
- Cursos gratuitos - SQL Server en Linux
- Tutorial: Migración de SQL Server a datos individuales en Azure SQL Database en línea usando DMS
- Tutorial: Migrar MySQL a Azure Database para MySQL en línea usando DMS
- Tutorial: Migración de PostgreSQL a Azure Database para PostgreSQL en línea usando DMS
- Tutorial: Migración de Oracle a Azure Database para PostgreSQL en línea usando DMS (versión preliminar)
- Guía de migración de Azure Database Migration
- Documentación oficial: migración de la base de datos de Azure
Espero que lo hayas disfrutado y nos vemos! Hasta muy pronto! 😃😃
Posted on February 13, 2020
Join Our Newsletter. No Spam, Only the good stuff.
Sign up to receive the latest update from our blog.