Nesta página, explicamos como exportar metadados do metastore do Dataproc.
O recurso de exportação de metadados permite salvar metadados em um formato de armazenamento portátil.
Depois de exportar seus dados, você pode importar os metadados para outro serviço do Metastore do Dataproc ou um metastore autogerenciado do Hive (HMS).
Sobre a exportação de metadados
Quando você exporta metadados do Metastore do Dataproc, o serviço armazena os dados em um dos seguintes formatos de arquivo:
- Um conjunto de arquivos Avro armazenados em uma pasta.
- Um único arquivo dump do MySQL armazenado em uma pasta do Cloud Storage.
Avro
As exportações baseadas em Avro são compatíveis apenas com as versões 2.3.6 e 3.1.2 do Hive. Quando
você exporta arquivos Avro, o Dataproc Metastore cria um
arquivo <table-name>.avro
para cada tabela no seu banco de dados.
Para exportar arquivos Avro, o serviço do Metastore do Dataproc pode usar o tipo de banco de dados MySQL ou Spanner.
MySQL
As exportações baseadas em MySQL são compatíveis com todas as versões do Hive. Ao exportar arquivos MySQL, o Dataproc Metastore cria um único arquivo SQL que contém todas as informações da tabela.
Para exportar arquivos MySQL, o serviço do metastore do Dataproc precisa usar o tipo de banco de dados MySQL. O tipo de banco de dados do Spanner não é compatível com importações do MySQL.
Antes de começar
- Ative o Dataproc Metastore no seu projeto.
- Entenda os requisitos de rede específicos do seu projeto.
- Crie um serviço Metastore do Dataproc.
Funções exigidas
Para receber as permissões necessárias para exportar metadados para a Metastore do Dataproc, peça ao administrador para conceder a você os seguintes papéis do IAM:
-
Para exportar metadados, faça o seguinte:
-
Editor do metastore do Dataproc (
roles/metastore.editor
) no serviço do metastore do Dataproc -
Administrador do metastore do Dataproc (
roles/metastore.admin
) no serviço do metastore do Dataproc -
Operador de metadados do metastore do Dataproc (
roles/metastore.metadataOperator
) no serviço do metastore do Dataproc
-
Editor do metastore do Dataproc (
-
Para usar o objeto do Cloud Storage para exportação no MySQL e no Avro, faça o seguinte:
Conceda à sua conta de usuário e ao agente de serviço do metastore do Dataproc a função Criador de armazenamento (
roles/storage.objectCreator
) no bucket do Cloud Storage
Para mais informações sobre a concessão de papéis, consulte Gerenciar o acesso a projetos, pastas e organizações.
Esses papéis predefinidos contêm as permissões necessárias para exportar metadados para o Dataproc Metastore. 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 exportar metadados para o Metastore do Dataproc:
-
Para exportar metadados:
metastore.services.export
no serviço do metastore -
Para usar o objeto do Cloud Storage para exportação no MySQL e no Avro, conceda à conta de usuário e ao agente de serviço do metastore do Dataproc:
storage.objects.create
no bucket do Cloud Storage
Essas permissões também podem ser concedidas com funções personalizadas ou outros papéis predefinidos.
Para mais informações sobre papéis e permissões específicos do Dataproc Metastore, consulte Visão geral do IAM do Dataproc Metastore.Exportar metadados
Antes de exportar os metadados, observe as seguintes considerações:
- Enquanto uma exportação está em execução, não é possível atualizar um serviço do Metastore do Dataproc, por exemplo, mudando as configurações. No entanto, ainda é possível usá-lo para operações normais, como acessar os metadados de clusters autogerenciados ou do Dataproc anexado.
- O recurso de exportação de metadados só exporta metadados. Os dados criados pelo Apache Hive em tabelas internas não são replicados na exportação.
Para exportar metadados de um serviço do metastore do Dataproc, siga as etapas abaixo.
Console
No console do Google Cloud, abra a página Metastore do Dataproc:
Na página Metastore do Dataproc, clique no nome do serviço de onde você quer exportar metadados.
A página Detalhes do serviço é aberta.
Na barra de navegação, clique em Exportar.
A página Exportar metadados é aberta.
Na seção Destino, escolha MySQL ou Avro.
No campo URI de destino, clique em Procurar e selecione o URI do Cloud Storage para onde você quer exportar os arquivos.
Você também pode inserir o local do bucket no campo de texto fornecido. Use o seguinte formato:
bucket/object
oubucket/folder/object
.Para iniciar a exportação, clique em Enviar.
Quando terminar, a exportação vai aparecer em uma tabela na página Detalhes do serviço na guia Importar/Exportar.
Quando a exportação é concluída, o Dataproc Metastore retorna automaticamente ao estado ativo, independente de a exportação ter sido bem-sucedida ou não.
CLI da gcloud
Para exportar metadados de um serviço, execute o seguinte comando
gcloud metastore services export gcs
:gcloud metastore services export gcs SERVICE \ --location=LOCATION \ --destination-folder=gs://bucket-name/path/to/folder \ --dump-type=DUMP_TYPE
Substitua:
SERVICE
: o nome do serviço do metastore do Dataproc.LOCATION
: a região do Google Cloud em que o serviço do Dataproc Metastore está localizado.bucket-name/path/to/folder
: a pasta de destino do Cloud Storage onde você quer armazenar a exportação.DUMP_TYPE
: o tipo de despejo de banco de dados a ser gerado pela exportação. Os valores aceitos incluemmysql
eavro
. O valor padrão émysql
.
Verifique se a exportação foi bem-sucedida.
Quando a exportação é concluída, o Dataproc Metastore retorna automaticamente ao estado ativo, independente de a exportação ter sido bem-sucedida ou não.
REST
Siga as instruções da API para exportar metadados para um serviço usando o APIs Explorer.
Quando a exportação é concluída, o serviço retorna automaticamente ao estado ativo, independente de ter sido bem-sucedida ou não.
Conferir o histórico de exportação
Para conferir o histórico de exportação de um serviço do metastore do Dataproc no console do Google Cloud, siga estas etapas:
- No console do Google Cloud, abra a página Metastore do Dataproc.
Na barra de navegação, clique em Importar/Exportar.
O histórico de exportação aparece na tabela Histórico de exportação.
O histórico mostra até as últimas 25 exportações.
A exclusão de um serviço do Metastore do Dataproc também exclui todo o histórico de exportação associado.
Resolver problemas comuns
Alguns problemas comuns incluem:
- A conta de usuário ou de agente de serviço não tem as permissões necessárias.
- O job falha porque o arquivo do banco de dados é muito grande.
Para mais ajuda na solução de problemas comuns, consulte Cenários de erro de importação e exportação.