Como automatizar implantações da SAP no Google Cloud com o Terraform

É possível automatizar a implantação da infraestrutura do Google Cloud usando o Terraform, uma ferramenta de código aberto que permite automatizar a criação e o gerenciamento de recursos do Google Cloud . Para mais informações sobre o Terraform, consulte Terraform com Google Cloud.

Para determinadas soluções SAP e bancos de dados de suporte, como SAP HANA, Google Cloud oferece arquivos de configuração do Terraform predefinidos que podem ser usados para implantar a infraestrutura do Google Cloud que atende aos requisitos de suporte e às práticas recomendadas da SAP.

Soluções SAP compatíveis

Google Cloud fornece arquivos de configuração do Terraform para as seguintes soluções SAP:

O que os arquivos de configuração implantam

Todos os arquivos de configuração do Terraform que o Google Cloud fornecem para implantações do SAP configuram ou implantam os seguintes elementos:

  • Uma ou mais máquinas virtuais (VMs) do Compute Engine
  • Uma imagem do SO que você especificar
  • Um ou mais volumes Persistent Disk ou hiperdisco
  • Opcionalmente, uma conta de serviço do Gerenciamento de identidade e acesso (IAM) especificada para uso pelas VMs
  • As APIs do Google Cloud exigidas pela implantação do SAP
  • Opcional: as tags de rede para cada instância de VM
  • Opcionalmente, um endereço IP externo para cada instância de VM
  • A versão mais recente do Google Cloud's agente para SAP

No SAP HANA, os arquivos de configuração do Terraform também implantam:

  • Volumes de armazenamento para /hana/data, /hana/log, /hana/shared, /usr/sap e /hanabackup
  • Opcionalmente, o próprio sistema SAP HANA
  • Para sistemas de escalonamento horizontal do SAP HANA com failover automático de host, 1 host mestre, até 15 hosts de worker e até 3 hosts de reserva
  • Um cluster de alta disponibilidade do Linux
  • Opcionalmente, para sistemas de escalonamento vertical do SAP HANA, endereços IP estáticos para as instâncias primária e secundária
  • Opcionalmente, para sistemas de escalonamento horizontal do SAP HANA, endereços IP estáticos para os nós mestre, de trabalho e em espera

Os arquivos de configuração do Terraform também são implantados para SAP NetWeaver:

  • Volumes de armazenamento para /sapmnt, /usr/sap e um volume de troca
  • Como opção, um cluster de alta disponibilidade do Linux no SLES

Para clusters de alta disponibilidade (HA, na sigla em inglês), os arquivos de configuração do Terraform também implantam funções e recursos extras, como balanceador de carga interno, grupo de instâncias e regras de encaminhamento. Para mais informações, consulte o guia de implantação para seu cenário de alta disponibilidade.

Configurações do Terraform para cada implantação SAP

Cada configuração predefinida do Terraform para SAP contém um arquivo de configuração declarativa DEPLOYMENT_TYPE.tf.

Para informações sobre os nomes dos arquivos de configuração ou como fazer o download deles, consulte o guia de implantação do seu cenário.

Como concluir o arquivo de configuração do Terraform

Os arquivos de configuração do Terraform fornecidos para implantações do SAP estão em conformidade com os padrões definidos pelo Terraform.

Os arquivos de configuração fornecidos para SAP incluem a definição do módulo principal seguido de comentários que declaram argumentos. O exemplo a seguir é um trecho do arquivo sap_hana.tf para implantar um sistema de escalonamento horizontal do SAP HANA sem nós em espera:

#...
module "sap_hana" {
  source = "https://storage.googleapis.com/cloudsapdeploy/terraform/latest/terraform/sap_hana/sap_hana_module.zip"
  #
  # By default, this source file uses the latest release of the terraform module
  # for SAP on Google Cloud. To fix your deployments to a specific release
  # of the module, comment out the source property above and uncomment the source property below.
  #
  # source = "https://storage.googleapis.com/cloudsapdeploy/terraform/YYYYMMDDHHMM/terraform/sap_hana/sap_hana_module.zip"
  # ...
  project_id = "example-project-123456"
  zone = "us-central1-f"
  machine_type = "n2-highmem-32"
  subnetwork = "example-subnet-us-central1"
  linux_image = "sles-15-sp2-sap"
  linux_image_project = "suse-sap-cloud"
  # ...
  instance_name = "hana-scaleout"
  # ...
  sap_hana_deployment_bucket = "mybucketname"
  sap_hana_sid = "AB2"
  sap_hana_instance_number = 12
  sap_hana_sidadm_password = "TempPa55word"
  sap_hana_system_password = "TempPa55word"
  sap_hana_scaleout_nodes = 3
  sap_hana_sidadm_uid = 11
  vm_static_ip = "10.0.0.1"
  worker_static_ips = ["10.0.0.2", "10.0.0.3", "10.0.0.4"]
  enable_fast_restart = true
  # ...
}

Para usar os argumentos opcionais, remova o caractere de comentário # e especifique um valor para o argumento. A maioria dos argumentos opcionais tem um valor padrão. Quando você não especifica um argumento opcional, a configuração do Terraform usa o valor padrão desse argumento, se houver.

Para mais informações sobre arquivos de configuração, consulte a documentação da linguagem Terraform.

Controle de versões do módulo

Os arquivos de configuração do Terraform DEPLOYMENT_TYPE.tf que você transfere por download do Google Cloud para implantações do SAP contêm duas instâncias do argumento source: uma que está ativa e outra incluída como um comentário. É possível controlar qual versão do módulo sua configuração usa removendo o caractere de comentário principal, #, do argumento source necessário e adicionando ao que você não precisa.

Por padrão, quando você faz o download de um novo arquivo de configuração do Terraform do Google Cloud para implantações SAP, o argumento source ativo especifica latest como a versão do módulo, o que significa que, se o Terraform atualizar os arquivos no diretório de trabalho ao inserir o comando terraform init, a configuração vai usar a versão mais recente disponível do módulo do Terraform que o Google Cloud fornece para implantações SAP.

A segunda instância do argumento source, que, por padrão, é desativada por um caractere # à esquerda, inclui o carimbo de data/hora que identifica a versão do módulo fornecido pelo Google Cloud. Por exemplo, no exemplo a seguir, 1.3.674800406 é o carimbo de data/hora que identifica a versão do módulo do Terraform.

#...
module "sap_hana" {
  source = "https://storage.googleapis.com/cloudsapdeploy/terraform/latest/terraform/sap_hana/sap_hana_module.zip"
  #...
  # source = "https://storage.googleapis.com/cloudsapdeploy/terraform/1.3.674800406/terraform/sap_hana/sap_hana_module.zip"
  #...
  # arguments...
  #...

Se você precisar que todas as implantações usem a mesma versão do módulo, no DEPLOYMENT_TYPE.tf, remova o caractere # inicial do argumento source que inclui a versão. timestamp e o adicione ao argumento source que especifica latest como a versão, conforme mostrado no exemplo a seguir:

#...
module "sap_hana" {
  # source = "https://storage.googleapis.com/cloudsapdeploy/terraform/latest/terraform/sap_hana/sap_hana_module.zip"
  #...
  source = "https://storage.googleapis.com/cloudsapdeploy/terraform/1.3.674800406/terraform/sap_hana/sap_hana_module.zip"
  #...
  # arguments...
  #...}

Quando um carimbo de data/hora é especificado, todas as implantações usam a versão do módulo do Terraform que corresponde ao carimbo de data/hora especificado.

Como implantar vários recursos com um arquivo de configuração

É possível implantar vários sistemas usando um único arquivo de configuração do Terraform. Para fazer isso, adicione blocos module ao arquivo de configuração para cada sistema extra que você precisa implantar.

Para implantações do SAP, copie a definição de bloco module fornecida pelo Google Cloud e cole na ordem adequada no arquivo de configuração.

Em cada bloco do módulo, especifique valores exclusivos para qualquer argumento específico da instância, como module ou instance_name.

Aplicar configurações

Para aplicar uma configuração do Terraform, use o comando terraform apply.

Se você quiser visualizar os resultados da configuração antes de implantar de fato recursos do Google Cloud , crie o plano de execução do Terraform usando o comando terraform plan.

Para procedimentos detalhados do aplicativo, consulte o guia de implantação do seu cenário.

Quando o Terraform conclui a aplicação da configuração, no Cloud Shell, ele exibe COMPLETED para cada um dos recursos criados e transmite o controle para o script de shell. O script de shell é invocado como script de inicialização nas VMs implantadas.

O script de shell faz outras configurações nos recursos implantados e registra o progresso no Cloud Logging. Uma implantação do SAP somente será concluída após o término do processamento dos scripts de shell.

Scripts pós-implantação

Use um script pós-implantação para executar outras ações, como acionar a instalação do aplicativo SAP NetWeaver, monitorar agentes etc.

Os scripts pós-implantação são o modo recomendado de personalizar a configuração, porque eles recebem o controle somente depois que a infraestrutura do Google Cloud é configurada de acordo com os requisitos de suporte do SAP.

Para exibir mensagens de status referentes aos scripts pós-implantação, você precisa codificá-los para gravar as mensagens nos registros. Para mais informações, consulte a documentação do Cloud Logging.

O status dos scripts de pós-implantação não está incluído nas mensagens que o Deployment Manager grava no Cloud Shell ou em uma sessão do shell da Google Cloud CLI.

Como receber suporte para as configurações do Terraform

Se você precisar de ajuda para resolver um problema com as configurações do Terraform que o Google Cloud oferece para SAP, colete as informações de diagnóstico necessárias e entre em contato com o Cloud Customer Care.

Para saber mais sobre como receber suporte para problemas com o Terraform, consulte Receber suporte para problemas do Terraform.