Integrar o Spanner com o Liquibase

Nesta página, descrevemos como gerenciar alterações no esquema do banco de dados do Spanner com o Liquibase.

O Liquibase é uma biblioteca de banco de dados de código aberto independente para rastrear, gerenciar e aplicar alterações de esquema de banco de dados. Ele é compatível com SQL, além de formatos declarativos, como XML, YAML e JSON.

O Liquibase pode ser destinado a bancos de dados do Spanner. Ele oferece suporte a todos recursos do Spanner, com algumas limitações.

  • Consulte as limitações gerais para saber mais.
  • Para saber mais sobre os bancos de dados de dialeto PostgreSQL, como os requisitos do Liquibase, tipos de alterações suportados e limitações, consulte PGAdapter e Liquibase.

Instalar o Liquibase

Para usar o Liquibase com bancos de dados de dialeto GoogleSQL, você precisa instalar o Extensão Spanner Liquibase. Para bancos de dados de dialeto PostgreSQL, o Liquibase pode usar o suporte integrado ao PostgreSQL em conjunto PGAdapter (em inglês).

GoogleSQL

  1. Siga as instruções na Documentação do Liquibase para instalar e configurar o Liquibase e capturar um snapshot do seu banco de dados. No arquivo de configuração liquibase.properties, defina a propriedade url como segue.

    jdbc:cloudspanner:/projects/PROJECT/instances/INSTANCE/databases/DATABASE
    

    Seu arquivo de configuração liquibase.properties pode conter apenas este valor . Outras propriedades são opcionais.

  2. Navegue até o liquibase do Spanner página de versões de extensão no GitHub e selecione versão mais recente.

  3. Selecione e faça o download do arquivo JAR com o nome liquibase-spanner-x.y.z-all.jar, em que xyz representa o número da versão da extensão. Por exemplo, liquibase-spanner-4.17.0-all.jar.

  4. Coloque o arquivo JAR transferido por download no diretório Lilibbase lib. O arquivo JAR inclui a extensão, o SDK do Spanner e o driver JDBC do Spanner motorista.

PostgreSQL

  1. Verificar se o PGAdapter está iniciado e em execução na máquina em que você instalará o Liquibase. Para mais informações, consulte Inicie o PGAdapter.

  2. Siga as instruções na Documentação do Liquibase para instalar e configurar o Liquibase e capturar um snapshot do seu banco de dados. No arquivo de configuração liquibase.properties, defina a propriedade url como segue.

    jdbc:postgresql://localhost:5432/DATABASE_NAME?options=-c%20spanner.ddl_transaction_mode=AutocommitExplicitTransaction
    

    Seu arquivo de configuração liquibase.properties pode conter apenas este valor . Outras propriedades são opcionais.

    A string url precisa incluir options=-c%20spanner.ddl_transaction_mode=AutocommitExplicitTransaction porque o Spanner não dá suporte a transações DDL, e isso garante que As transações DDL são convertidas automaticamente em lotes DDL. Para mais informações, consulte Opções de DDL para PGAdapter.

Analisar as amostras do Liquibase

GoogleSQL

O exemplo de arquivo de registro de alterações changelog.yaml incluído no A extensão GoogleSQL Liquibase demonstra muitos dos recursos do Liquibase e como usá-los com o Spanner.

PostgreSQL

O exemplo de arquivo de registro de alterações dbchangelog.xml, disponível no Repositório PGAdapter e Liquibase do GitHub demonstra muitos dos recursos do Liquibase e como usá-los com no Spanner.

Guia de início rápido do Liquibase

Neste guia de início rápido, mostramos como usar o Liquibase para adicionar uma tabela Singers a uma no seu banco de dados.

Antes de começar

  • Verifique se você concluiu as etapas anteriores de instalação. Liquibase.

  • Criar uma instância do Spanner.

  • Criar um banco de dados de dialeto GoogleSQL ou PostgreSQL.

  • Apenas para bancos de dados de dialeto PostgreSQL, verifique se o PGAdapter está iniciado e em execução na mesma máquina da instalação do Liquibase. Para mais informações, consulte Inicie o PGAdapter.

  • Somente para bancos de dados de dialeto PostgreSQL, crie os atributos databasechangeloglock e tabelas de metadados databasechangelog usando o create_database_change_log.sql. Você deve criar essas tabelas para substituir as tabelas que o Liquibase cria automaticamente no banco de dados. Isso garante que os tipos de dados PostgreSQL corretos para O Spanner é usado nessas tabelas.

    É possível executar o script com o seguinte comando:

    psql -h localhost -d DATABASE_NAME -f create_database_change_log.sql
    
  • Permitir que a extensão Spanner Liquibase use temporariamente a própria extensão Credenciais de usuário do Spanner para acesso à API executando o seguinte Comando gcloud:

    gcloud auth application-default login
    

Criar um changelog.yaml

  1. Insira o seguinte YAML no seu editor favorito.

    databaseChangeLog:
      - preConditions:
         onFail: HALT
         onError: HALT
    
      - changeSet:
         id: create-singers-table
         author: spanner-examples
         changes:
           - createTable:
              tableName: Singers
              columns:
                -  column:
                    name:    SingerId
                    type:    BIGINT
                    constraints:
                      primaryKey: true
                      primaryKeyName: pk_Singers
                -  column:
                    name:    Name
                    type:    VARCHAR(255)
    

    Esse YAML define uma tabela chamada Singers com uma chave primária SingerId e uma coluna chamada Name para armazenar o nome do cantor.

    Para bancos de dados de dialeto PostgreSQL, recomendamos usar letras minúsculas em tabelas e colunas nomes de domínio. Para mais informações, consulte Sensibilidade de maiúsculas e minúsculas do PostgreSQL.

    O conjunto de mudanças createTable precisa incluir uma restrição de chave primária, e o nome da restrição da chave primária precisa ser pk_table_name.

  2. Salve as mudanças como changelog.yaml.

Executar o Liquibase

Aplique o conjunto de mudanças em changelog.yaml executando o seguinte comando:

liquibase --changeLogFile changelog.yaml update

O Liquibase usa o URL definido no arquivo liquibase.properties. Você pode substituir o valor no arquivo adicionando o seguinte argumento ao comando anterior:

--url URL

Verificar suas alterações

As atualizações na etapa anterior fizeram com que a tabela Singer fosse adicionada ao seu no seu banco de dados. Além disso, as tabelas DATABASECHANGELOG e DATABASECHANGELOGLOCK foram adicionado (banco de dados de dialeto GoogleSQL) ou atualizado (banco de dados de dialeto PostgreSQL).

É possível verificar a existência dessas tabelas pelo console do Google Cloud ou CLI gcloud. Por exemplo, executar a consulta SQL SELECT * FROM INFORMATION_SCHEMA.TABLES retorna uma lista de todas as tabelas no banco de dados.

gcloud spanner databases execute-sql DATABASE_NAME --instance=INSTANCE \
    --sql='SELECT * FROM INFORMATION_SCHEMA.TABLES'

É possível ver um registro das mudanças que foram aplicadas consultando o conteúdo de DATABASECHANGELOG.

A seguir