Atualizar uma implementação

Depois de ter uma implementação, pode atualizá-la à medida que a sua app evolui. Pode usar o Deployment Manager para atualizar uma implementação:

  • Adicionar ou remover recursos da implementação
  • Atualizar algumas propriedades de recursos existentes na sua implementação

O Deployment Manager usa as APIs subjacentes dos Google Cloud serviços para gerir recursos na sua implementação. O Deployment Manager pode atualizar os recursos existentes se existir um método update ou patch na API correspondente.

Implemente a configuração original

Neste passo, implemente a configuração que vai atualizar mais tarde. Navegue para a pasta no repositório do GitHub e implemente a configuração:

cd deploymentmanager-samples/examples/v2/step_by_step_guide/step8_metadata_and_startup_scripts/python

gcloud deployment-manager deployments create deployment-to-update --config config-with-many-templates.yaml

A configuração implementa duas máquinas virtuais (VMs) que executam um script de arranque. O modelo de VM é:

# Copyright 2016 Google Inc. All rights reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
#     http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.

"""Creates the virtual machine with environment variables and startup script."""


COMPUTE_URL_BASE = 'https://www.googleapis.com/compute/v1/'


def GenerateConfig(context):
  """Creates the virtual machine."""

  resources = [{
      'name': context.env['name'],
      'type': 'compute.v1.instance',
      'properties': {
          'zone': context.properties['zone'],
          'machineType': ''.join([COMPUTE_URL_BASE, 'projects/',
                                  context.env['project'], '/zones/',
                                  context.properties['zone'], '/machineTypes/',
                                  context.properties['machineType']]),
          'disks': [{
              'deviceName': 'boot',
              'type': 'PERSISTENT',
              'boot': True,
              'autoDelete': True,
              'initializeParams': {
                  'sourceImage': ''.join([COMPUTE_URL_BASE, 'projects/',
                                          'debian-cloud/global/',
                                          'images/family/debian-11'])
              }
          }],
          'networkInterfaces': [{
              'network': '$(ref.' + context.properties['network']
                         + '.selfLink)',
              'accessConfigs': [{
                  'name': 'External NAT',
                  'type': 'ONE_TO_ONE_NAT'
              }]
          }],
          'metadata': {
              'items': [{
                  'key': 'startup-script',
                  'value': ''.join(['#!/bin/bash\n',
                                    'python -m SimpleHTTPServer 80'])
              }]
          }
      }
  }]
  return {'resources': resources}

Abra o modelo atualizado

Agora, abra o modelo atualizado:

cd deploymentmanager-samples/examples/v2/step_by_step_guide/step9_update_a_deployment/python

nano vm-template.py

No modelo atualizado, na secção metadata, o script de arranque da MV foi alterado:

# Copyright 2016 Google Inc. All rights reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
#     http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.

"""Creates the virtual machine with environment variables and startup script."""


COMPUTE_URL_BASE = 'https://www.googleapis.com/compute/v1/'


def GenerateConfig(context):
  """Creates the virtual machine."""

  resources = [{
      'name': context.env['name'],
      'type': 'compute.v1.instance',
      'properties': {
          'zone': context.properties['zone'],
          'machineType': ''.join([COMPUTE_URL_BASE, 'projects/',
                                  context.env['project'], '/zones/',
                                  context.properties['zone'], '/machineTypes/',
                                  context.properties['machineType']]),
          'disks': [{
              'deviceName': 'boot',
              'type': 'PERSISTENT',
              'boot': True,
              'autoDelete': True,
              'initializeParams': {
                  'sourceImage': ''.join([COMPUTE_URL_BASE, 'projects/',
                                          'debian-cloud/global/',
                                          'images/family/debian-11'])
              }
          }],
          'networkInterfaces': [{
              'network': '$(ref.' + context.properties['network']
                         + '.selfLink)',
              'accessConfigs': [{
                  'name': 'External NAT',
                  'type': 'ONE_TO_ONE_NAT'
              }]
          }],
          'metadata': {
              'items': [{
                  'key': 'startup-script',
                  'value': ''.join(['#!/bin/bash\n',
                                    'INSTANCE=$(curl http://metadata.google.',
                                    'internal/computeMetadata/v1/instance/',
                                    'hostname -H "Metadata-Flavor: Google")\n',
                                    'echo "<html><header><title>Hello from ',
                                    'Deployment Manager!</title></header>',
                                    '<body><h2>Hello from $INSTANCE</h2><p>',
                                    'Deployment Manager bids you good day!</p>',
                                    '</body></html>" > index.html\n',
                                    'python -m SimpleHTTPServer 80\n'])
              }]
          }
      }
  }]
  return {'resources': resources}

Vai usar este modelo atualizado para alterar a implementação que criou.

Pré-visualize a atualização

Para pré-visualizar a implementação atualizada, execute o comando update com uma flag --preview:

gcloud deployment-manager deployments update deployment-to-update --config config-with-many-templates.yaml --preview

Confirme a atualização

Para confirmar a atualização, execute o seguinte comando:

gcloud deployment-manager deployments update deployment-to-update

Valide a atualização

Para verificar se a atualização funcionou, tem de reiniciar primeiro as instâncias para usar o novo script de arranque. Reiniciar the-first-vm:

gcloud compute instances reset the-first-vm

A instância pode demorar algum tempo a ser reiniciada. Aguarde alguns minutos antes de confirmar a alteração.

Confirme o novo script de arranque

  1. Obtenha o IP externo de the-first-vm:

    gcloud compute instances describe the-first-vm | grep "natIP"
    
  2. Copie o valor.

  3. Abra um navegador e cole o endereço IP na barra de endereço para visitar a sua instância.

    A página deve apresentar agora uma mensagem de boas-vindas que indica: "O Deployment Manager deseja-lhe um bom dia!"

Também pode repetir estes passos com the-second-vm e ver uma mensagem ligeiramente diferente.

Elimine a sua implementação

Tal como nos passos anteriores, recomendamos que elimine a implementação para evitar cobranças. Execute o seguinte comando para eliminar a implementação:

gcloud deployment-manager deployments delete deployment-to-update

O que se segue?

Seguem-se algumas áreas a explorar à medida que usa o Deployment Manager: