Utilizzo di variabili di ambiente specifiche per il deployment

Per ogni implementazione, Deployment Manager crea variabili di ambiente predefinite che contengono informazioni dedotte dall'implementazione. Utilizza queste variabili di ambiente nei modelli Python o Jinja2 per ottenere informazioni sul progetto o sul deployment.

Prima di iniziare

Variabili di ambiente disponibili

Le seguenti variabili di ambiente vengono impostate automaticamente da Deployment Manager. Vengono sostituiti ovunque li utilizzi nei tuoi modelli. Ad esempio, utilizza la variabile project_number per aggiungere il numero del progetto al nome di un account di servizio.

Variabile di ambiente Valore
deployment Il nome del deployment.
name Il name dichiarato nella configurazione che utilizza il modello. Questo può essere utile se vuoi che il nome dichiarato nella configurazione sia il nome della risorsa nei modelli sottostanti.
project L'ID progetto per questo deployment.
project_number Il numero del progetto per questo deployment.
current_time Il timestamp UTC in cui è iniziata l'espansione per il deployment.
type Il tipo di risorsa dichiarato nella configurazione di primo livello.
username L'utente corrente di Deployment Manager.

Utilizzo di una variabile di ambiente

Utilizza la seguente sintassi per aggiungere una variabile di ambiente ai modelli:

{{ env["deployment"] }} # Jinja

context.env["deployment"] # Python

Nel modello, utilizza le variabili come in questi esempi:

Jinja

- type: compute.v1.instance
  name: vm-{{ env["deployment"] }}
  properties:
    machineType: zones/us-central1-a/machineTypes/f1-micro
    serviceAccounts:
    - email: {{ env['project_number'] }}-compute@developer.gserviceaccount.com
      scopes:
      - ...

Python

def GenerateConfig(context):
  resources = []
  resources.append ({
    'name': 'vm-' + context.env["deployment"],
    'type': 'compute.v1.instance',
    'properties': {
       'serviceAccounts': [{
         'email': context.env['project_number'] + '-compute@developer.gserviceaccount.com',
         'scopes': [...]
       }]
    }
    ...}]
  return {'resources': resources}

Passaggi successivi