O Database Migration Service usa jobs para migrar dados dos bancos de dados de origem para a instância de destino do Cloud SQL. Os jobs de migração ajudam a organizar os perfis de conexão de origem e destino, definir configurações específicas para o processo de migração, monitorar o progresso e concluir toda a operação com segurança.
A criação de um job de migração inclui as seguintes tarefas:
Selecionar perfis de conexão de origem e destino.
Escolher quais bancos de dados detectados na instância de origem você quer migrar.
Realizar um teste de job de migração para garantir que o Database Migration Service possa se conectar à origem e ao destino dos dados.
Iniciar o job de migração e monitorar o progresso.
Promover o job de migração quando você quiser mudar o aplicativo para a nova instância.
Antes de começar
- Verifique se você atende aos seguintes requisitos:
- Você tem um bucket do Cloud Storage para arquivos de backup do SQL Server.
- Seus arquivos de backup completo e de registro de transações são enviados para o bucket do Cloud Storage.
- Você tem um perfil de conexão de origem para o bucket do Cloud Storage.
- Você criou e configurou a instância de destino do Cloud SQL para SQL Server e tem um perfil de conexão de destino para ela.
- No console do Google Cloud , na página do seletor de projetos, selecione ou crie um Google Cloud projeto.
- Ative as APIs Database Migration Service, Compute Engine, Cloud Storage e Cloud SQL Admin.
Funções exigidas
Para receber as permissões necessárias para criar jobs de migração no Database Migration Service, peça ao administrador para conceder a você os seguintes papéis do IAM no projeto:
-
Administrador de migração do banco de dados (
roles/datamigration.admin
) -
Administrador do Storage (
roles/storage.admin
) -
Editor do Cloud SQL (
roles/cloudsql.editor
)
Para mais informações sobre como conceder papéis, consulte Gerenciar acesso.
Esses papéis predefinidos contêm as permissões necessárias para realizar migrações homogêneas do SQL Server com o Database Migration Service. Para conferir as permissões exatas necessárias, expanda a seção Permissões necessárias:
Permissões necessárias
As permissões a seguir são necessárias para realizar migrações homogêneas do SQL Server com o Database Migration Service:
datamigration.*
resourcemanager.projects.get
resourcemanager.projects.list
cloudsql.instances.create
cloudsql.instances.get
cloudsql.instances.list
cloudsql.databases.get
cloudsql.databases.delete
cloudsql.operations.get
compute.machineTypes.list
compute.machineTypes.get
compute.projects.get
storage.buckets.create
storage.buckets.list
storage.objects.list
Essas permissões também podem ser concedidas com papéis personalizados ou outros papéis predefinidos.
Definir configurações e criar um job de migração
Para criar um job de migração, siga estas etapas:
Console
- No console Google Cloud , acesse a página Jobs de migração.
- Clique em Criar job de migração.
A página do assistente de configuração do job de migração é aberta. Esse assistente contém vários painéis que mostram cada etapa de configuração.
É possível pausar a criação de um job de migração a qualquer momento clicando em SALVAR E SAIR. Todos os dados inseridos até esse ponto são salvos em um rascunho de job de migração. Você pode concluir o rascunho do job de migração depois. Consulte Atualizar um job de migração em rascunho.
- Na página Começar, insira as seguintes informações:
- Nome do job de migração
É um nome legível para o job de migração. Esse valor é exibido no console Google Cloud .
- ID do job de migração
É um identificador legível por máquina do seu job de migração. Use esse valor para trabalhar com jobs de migração usando comandos da CLI do Google Cloud ou da API do Database Migration Service.
- Na lista Mecanismo de banco de dados de origem, selecione SQL Server ou Amazon RDS para SQL Server.
Os campos Mecanismo do banco de dados de destino e Tipo de job de migração são preenchidos automaticamente e não podem ser alterados.
- Nome do job de migração
- Clique em Salvar e continuar.
- Na página Definir sua origem, faça o seguinte:
- Use o menu suspenso para selecionar seu perfil de conexão de origem.
Se você ainda não tiver um perfil de conexão de origem, clique em Criar perfil de conexão diretamente no menu suspenso. Para mais informações sobre como criar perfis de conexão, consulte Criar um perfil de conexão de origem.
- Se você quiser usar um arquivo de backup diferencial na migração,
na seção Personalizar configurações de origem, marque a caixa de seleção
Usar backups diferenciais.
Os backups diferenciais são úteis se você precisar replicar muitos dados que apareceram no banco de dados desde o backup completo e quiser processá-los em massa em vez de fazer upload de vários arquivos de registro de transações. Para mais informações sobre os tipos de backup compatíveis, consulte Tipos de arquivos de backup compatíveis.
Se você usar backups diferenciais, crie a pasta
diff
no bucket do Cloud Storage. Consulte Armazenar arquivos de backup em um bucket do Cloud Storage. - Clique em Salvar e continuar.
- Use o menu suspenso para selecionar seu perfil de conexão de origem.
- Na página Definir um destino, use o menu suspenso para selecionar seu perfil de conexão de destino.
Se você ainda não tiver um perfil de conexão de destino, clique em Criar perfil de conexão diretamente no menu suspenso. Para mais informações sobre como criar perfis de conexão, consulte Criar um perfil de conexão de destino.
- Clique em Salvar e continuar.
- Na página Configurar bancos de dados de migração, faça o seguinte:
- Na seção Selecionar bancos de dados para migrar, use as
caixas de seleção para escolher quais bancos de dados você quer incluir neste
job de migração. Essa lista é preenchida com base nas pastas criadas
no bucket do Cloud Storage para seus arquivos de backup.
É possível adicionar e remover bancos de dados do job de migração depois. Consulte Adicionar ou remover bancos de dados de um job de migração.
- (Opcional) Se você usa backups criptografados, forneça as chaves de criptografia dos seus backups. Para mais detalhes sobre como usar backups criptografados, consulte
Usar backups criptografados.
Execute estas ações:
- Clique em Editar detalhes ao lado do banco de dados selecionado para migração.
O painel lateral Criptografia é aberto.
- Use os menus suspensos Chave de criptografia para selecionar suas chaves.
- No campo Senha, digite a senha da chave de criptografia.
- Clique em Salvar e sair.
- Clique em Editar detalhes ao lado do banco de dados selecionado para migração.
- Na seção Selecionar bancos de dados para migrar, use as
caixas de seleção para escolher quais bancos de dados você quer incluir neste
job de migração. Essa lista é preenchida com base nas pastas criadas
no bucket do Cloud Storage para seus arquivos de backup.
- Clique em Salvar e continuar.
- Na página Testar e criar job de migração, faça o seguinte:
- (Opcional) Clique em Testar job para verificar se o Database Migration Service
consegue identificar todos os arquivos de backup e estabelecer
as conexões de rede necessárias.
Se o teste falhar, consulte as mensagens de erro para resolver o problema e execute o teste novamente. Para mais informações sobre possíveis erros, consulte Diagnosticar problemas.
- Clique em Criar e iniciar job para começar a migração.
Se quiser executar o job de migração em outro momento, clique em Salvar e volte depois para executar o job. Consulte Iniciar um job de migração.
- (Opcional) Clique em Testar job para verificar se o Database Migration Service
consegue identificar todos os arquivos de backup e estabelecer
as conexões de rede necessárias.
gcloud
Este exemplo usa a flag opcional --no-async
para que todas as operações
sejam realizadas de forma síncrona. Isso significa que alguns comandos podem levar
um tempo para serem concluídos. Você pode pular a flag --no-async
para executar comandos de forma assíncrona.
Se você fizer isso, use o comando
gcloud database-migration operations describe
para verificar se a operação foi bem-sucedida.
Antes de usar os dados do comando abaixo, faça estas substituições:
- MIGRATION_JOB_ID com um identificador legível por máquina para seu job de migração. Você usa esse valor para trabalhar com jobs de migração usando comandos da CLI do Google Cloud ou a API do Database Migration Service.
- REGION com o identificador da região em que você quer salvar o job de migração.
- MIGRATION_JOB_NAME com um nome legível para o job de migração. Esse valor é exibido no Database Migration Service no console Google Cloud .
- SOURCE_CONNECTION_PROFILE_ID com um identificador legível por máquina do perfil de conexão de origem.
- DESTINATION_CONNECTION_PROFILE_ID com um identificador legível por máquina do perfil de conexão de destino.
- COMMA_SEPARATED_DATABASE_ID_LIST com uma
lista separada por vírgulas de identificadores de banco de dados do SQL Server que você quer
migrar dos arquivos de backup. Esses identificadores precisam ser iguais aos
nomes das pastas de banco de dados no Cloud Storage.
Por exemplo:
--sqlserver-databases=my-business-database,my-other-database
- Configuração de backup diferencial: se você usar arquivos de backup diferencial para a
migração, adicione a flag
--sqlserver-diff-backup
ao comando. Por padrão, os jobs de migração não usam arquivos de backup diferencial e ignoram a pastadiff
no bucket do Cloud Storage.Para mais informações sobre os arquivos de backup compatíveis, consulte Tipos de arquivos de backup compatíveis.
- (Opcional) MAPPING_FILE_FOR_PATHS_TO_ENCRYPTION_KEYS
com o caminho do disco local para um arquivo de configuração que mapeia caminhos para chaves de criptografia no Cloud Storage
com os identificadores de banco de dados relevantes. Para mais informações sobre como criar esse arquivo de mapeamento, consulte Usar backups criptografados.
Por exemplo:
--sqlserver-encrypted-databases=~/encryption-keys-mapping-file.json
Execute o seguinte comando:
Linux, macOS ou Cloud Shell
gcloud database-migration migration-jobs \ create MIGRATION_JOB_ID \ --no-async \ --region=REGION \ --display-name=MIGRATION_JOB_NAME \ --source=SOURCE_CONNECTION_PROFILE_ID \ --destination=DESTINATION_CONNECTION_PROFILE_ID \ --sqlserver-databases=COMMA_SEPARATED_DATABASE_ID_LIST \ --sqlserver-encrypted-databases=MAPPING_FILE_FOR_PATHS_TO_ENCRYPTION_KEYS \ --type=CONTINUOUS
Windows (PowerShell)
gcloud database-migration migration-jobs ` create MIGRATION_JOB_ID ` --no-async ` --region=REGION ` --display-name=MIGRATION_JOB_NAME ` --source=SOURCE_CONNECTION_PROFILE_ID ` --destination=DESTINATION_CONNECTION_PROFILE_ID ` --sqlserver-databases=COMMA_SEPARATED_DATABASE_ID_LIST ` --sqlserver-encrypted-databases=MAPPING_FILE_FOR_PATHS_TO_ENCRYPTION_KEYS ` --type=CONTINUOUS
Windows (cmd.exe)
gcloud database-migration migration-jobs ^ create MIGRATION_JOB_ID ^ --no-async ^ --region=REGION ^ --display-name=MIGRATION_JOB_NAME ^ --source=SOURCE_CONNECTION_PROFILE_ID ^ --destination=DESTINATION_CONNECTION_PROFILE_ID ^ --sqlserver-databases=COMMA_SEPARATED_DATABASE_ID_LIST ^ --sqlserver-encrypted-databases=MAPPING_FILE_FOR_PATHS_TO_ENCRYPTION_KEYS ^ --type=CONTINUOUS
Você receberá uma resposta semelhante a esta:
Waiting for migration job [MIGRATION_JOB_ID] to be created with [OPERATION_ID] Waiting for operation [OPERATION_ID] to complete...done. Created migration job MIGRATION_JOB_ID [OPERATION_ID]
O job de migração foi criado. Você pode continuar com o processo de migração:
- (Opcional) Faça um teste de job de migração para verificar se o Database Migration Service pode alcançar todas as entidades de origem e destino necessárias.
- Inicie o job de migração para começar a mover seus dados para a instância de destino.