Parece algo difícil quando se lê o título, não é mesmo? Mas, quero mostrar a todos vocês aqui que é bem mais fácil do que vocês imaginam!
Vamos entender os passos a serem feitos e verão que é extremamente fácil e uma migração bastante fácil. Vamos nessa?
O que é o Azure SQL Database?
Antes de realizar a migração nesse tutorial, gostaria de explicar um pouco o que seria o Azure SQL Database.
O Azure SQL Database é um banco de dados relacional, fornecido como um serviço gerenciado. Através dele, vocês podem criar uma camada de armazenamento de dados altamente disponível e de alto desempenho para as aplicações e soluções no Azure. E ele acaba sendo uma escolha muito interessante uma vez que nos permite processar dados relacionais e estruturas não relacionais, como por exemplo: Grafos, JSON, XML e espaciais.
Além disso, o seu serviço é totalmente gerenciado que possui uma alta disponibilidade interna, backups e outras operações de manutenção comuns. Ou seja, a Microsoft trata de todas as correções e atualizações do código do sistema operacional e do SQL. Resumindo: você não precisa gerenciar a infraestrutura subjacente! E isso já é uma vantagem muito grande!
Outro ponto importante a mencionar sobre as opções de implantação para Azure SQL Database:
- Banco de dados Individual: representa um banco de dados isolado e totalmente gerenciado.
- Instância Gerenciada: é uma instância totalmente gerenciada do mecanismo de banco de dados do Microsoft SQL Server. O que facilita a realização da migração de banco de dados locais SQL Server para a nuvem do Azure.
- Pool Elástico: é uma coleção de banco de dados individuais com um conjunto compartilhado de recursos, como CPU ou memória.
As explicações acima estão sintetizadas. Mas, se desejarem saber mais detalhes de cada opção de implantação disponível, podem saber mais AQUI.
Bom, vamos ao que interessa! A demo!
Primeiros Passos!
Antes de mais nada, gostaria de falar com vocês que no meu caso, eu preferi criar uma VM do SQL Server 2017 no Azure. Para que não haja a necessidade de baixar o SQL Server Management Studio na minha máquina local, para fins de demo! Mas, se vocês desejarem, posso estar escrevendo um outro artigo, explicando passo a passo como criar uma VM do SQL Server 2017 no Azure e como conectar de maneira correta na sua máquina local – e melhor como habilitar e configurar de maneira muito simples o firewall da VM criada! Se desejarem esse artigo, deixem nos comentários abaixo! 😃
Abaixo vejam a VM do Azure SQL Server criada no Azure sendo executada na minha máquina local:
Lindo demais, não é mesmo?! Lembrando que você pode criar VMs do SQL Server no Azure tanto para Windows como para Linux também! #ficaadica
Outro ponto importante: se vocês tiverem o SQL Server Management Studio instalado localmente na sua máquina, não tem problema. Podem seguir esse tutorial que vai dar tudo certo!
Bom, abri na minha VM o Microsoft SQL Server Management Studio e criei, para fins de demo, uma base de dados super simples e básica. Se desejarem, podem copiar o script abaixo:
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 podem ver uma base de dados simples que possuem apenas 3 tabelas e alguns inserts! Vamos executar essa query no SQL Server Management Studio.
No final teremos 3 tabelas contidas dentro da base de dados: demosqlazuredb
Agora cliquem com o botão direito na base de dados: demosqlazuredb e vão até: Tasks -> Deploy Database to Microsoft Azure SQL Database:
Depois de clicar aparecerá uma outra janela pedindo algumas informações importantes. Bastam clicar em: Next
Vamos agora especificar onde será migrada a nossa base de dados! Para isso, cliquem em: Connect.
Após clicar em Connect aparecerá uma nova janela para que você informe os dados da sua conexão, conforme a imagem abaixo:
Talvez vocês estejam se perguntando, se estou migrando do local para nuvem então preciso criar uma instância lógica na nuvem para conectar com essa migração? Se essa pergunta passou na cabeça de vocês, estão pensando corretamente! Agora nesse momento precisamos criar essa instância lógica no Azure e é justamente o que vamos fazer agora!
Criando SQL Database no Azure
Bom, minizem o SQL Server Management Studio e abram o Portal Azure.
Conta – Azure for Students ⭐️
Caso você seja um(a) estudante de alguma Instituição de Ensino de Faculdade ou Universidade, poderá criar sua conta no Azure for Students. Essa conta te dará o benefício em possuir crédito de USD 100,00 para usar os serviços de maneira gratuita, sem necessidade de possuir um cartão de crédito. Para ativar essa conta, bastam acessar o link ao lado: AQUI
Depois de entrar no Portal Azure, vamos seguir os seguintes passos:
- Clique no Menu hamburger -> SQL databases
- Clique em: Add
- Preencher todos os campos solicitados: Subscription(sua assinatura) e Resource Group. Se não tiver um, basta criar, clicando em: 'Create new'. Depois informe o: Database name.
- Depois vocês precisarão criar um Server. Para isso, bastam clicar em: 'Create new'. Ao clicar, aparecerá uma janela ao lado. Preencha todos os campos necessários e inclua um login e password que você não se esqueça. E depois cliquem em: Ok
Dica: procure anotar num bloco de notas, pois vamos precisar dessa senha e login mais tarde!
- Agora cliquem em: Compute + storage -> Configure database.
- Ao clicar, aparecerá uma outra janela. Como se trata de uma demo simples de migração, vamos escolher o plano mais básico. Cliquem em: Basic -> Apply.
- Depois cliquem em: Review + Create e enfim em: Create
- Após finalizar cliquem em: Go to Resource
- Agora vai abrir o Dashboard do recurso recém criado. Porém, vamos fazer algo muito importante: configurar o firewall! Para isso, vão até: Overview -> Set server firewall. Vai abrir uma outra janela:
- Agora que estamos no Firewall Settings, cliquem em: Add client IP, cliquem em: OK (Allow Azure Services…), incluam o IP da máquina de vocês e depois cliquem em: Save.
p.s.: se desejarem saber mais informações a respeito das regras de firewall de IP no Azure SQL Server, bastam acessar: AQUI
- Copiem o Server name. Pois precisaremos dele para o passo a seguir!
Bom! Agora a nossa instância está devidamente criada e configurada! Agora, vamos terminar de realizar a migração!
Retornando ao SQL Server Management Studio localmente
Voltemos aquela janela de conexão que paramos e vamos realizar a devida conexão. E inclua as seguintes informações:
- Server name: você obterá essa informação no recurso criado no passo anterior, clicando em Overview no Portal Azure (passo anterior)
- Authentication: alteraer para SQL Server Authentication
- Login: criado no passo anterior
- Password: criado no passo anterior E enfim, cliquem em: Connect.
p.s.: login e password do recurso criado no Azure!!!
Notem que podemos alterar o quanto precisaremos gastar nessa base dados. Podemos realizar essa alteração também nessa parte do processo. Isso dependerá da quantidade de dados que você irá migrar para a nuvem! Vocês podem usar a calculadora que está disponível AQUI. No nosso caso, como estamos realizando uma demo, vamos usar o plano Basic e o size: 2.
Depois cliquem em: Next
E finalmente cliquem em: Finish
No ato que que você clicar em Finish, começará a migração que fará com que exporte todas as tarefas.
Quando aparecer a mensagem: Operation Complete é porque a migração foi realizada com sucesso. Observe que, o schema, as tabelas, tudo foi migrado com sucesso!
Agora, podem fechar o SQL Server Management e vamos ver o que aconteceu, porém agora lá no Portal Azure!
Abram o Portal Azure e vão até: SQL Databases e vejam o que vai aparecer:
Vai aparecer justamente, a base de dados criada logicamente e a que migramos (que poderia representar a base de dados em produção – por exemplo). Clique na base recém migrada: (demosqlazuredb)
Agora clique em: Query editor (preview) e inclua a senha criada nesse recurso. Vamos fazer algumas queries de SQL nessa base de dados recém migrada!
Agora observem no gif, como os dados que antes estavam contidos localmente no SQL Server Management Studio, agora estão disponíveis na nuvem!
Sensacional, não é mesmo? Podemos: importar, exportar, criar Stored Procedures e muito mais! 😊
Database Migration Assistant
Podemos realizar a migração dos nossos dados locais do SQL server usando uma ferramenta chamada: Database Migration Assistant. Essa ferramenta ela foi criada para automatizar a migração do banco de dados para SQL Server do Microsoft Access, DB2, MYSQL, Oracle e SAP ASE.
Se desejarem obter informações de como realizar a migração usando o Database Migration Assistent em nas bases de dados abaixo, deixo os recursos disponíveis abaixo:
- 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
Há um tutorial que ensina, passo a passo como vocês podem usar essa ferramenta excelente que facilita e muito na hora de realizar a migração: AQUI.
Próximos Passos
Hoje aprendemos, que com poucos passos, o quão fácil é realizar a migração da nossa base local (on premises) para a nuvem. E que podemos fazer uso de uma outra ferramenta que nos auxilia para projetar e automatizar esse processo de migração em diferentes bases de dados!
Novamente, se desejarem uma parte 2 desse tutorial ensinando passo a passo como realizar a migração usando o Database Migration Assistant e também como criar uma VM do SQL Server 2016/2017 no Azure, bastam deixar aqui nos comentários abaixo!
E se desejarem saber mais sobre o Azure SQL Database, temos inúmeros recursos, tutoriais e links que podem ajudar a todos para estudos e aplicação no mundo real:
- Cursos grátis – SQL Server no Linux
- Tutorial: Migrando SQL Server para dados Individual no Azure SQL Database online usando DMS
- Tutorial: Migrando o MySQL para o Azure Database for MySQL online usando o DMS
- Tutorial: Migrando o PostgreSQL para o Azure Database for PostgreSQL online usando o DMS
- Tutorial: Migrando o Oracle para o Azure Database for PostgreSQL online usando DMS (versão preview)
- Guia de Migração do Azure Database Migration
- Documentação Oficial – Azure Database Migration
E para ficarem por dentro de várias outras novidades, não deixem de me seguir lá no twitter!
Nos vemos! Até a próxima pessoal! 😍
Top comments (0)