New in version 1.4.
- python >= 2.6
- apache-libcloud >= 0.13.3, >= 0.17.0 if using JSON credentials, >= 0.20.0 if using preemptible option
parameter | required | default | choices | comments |
---|---|---|---|---|
credentials_file (added in 2.1.0) |
no |
path to the JSON file associated with the service account email
|
||
disk_auto_delete (added in 1.9) |
no | true |
if set boot disk will be removed after instance destruction
|
|
disk_size (added in 2.3) |
no | 10 |
The size of the boot disk created for this instance (in GB)
|
|
disks (added in 1.7) |
no |
a list of persistent disks to attach to the instance; a string value gives the name of the disk; alternatively, a dictionary value can define 'name' and 'mode' ('READ_ONLY' or 'READ_WRITE'). The first entry will be the boot disk (which must be READ_WRITE).
|
||
external_ip (added in 1.9) |
no | ephemeral |
type of external ip, ephemeral by default; alternatively, a fixed gce ip or ip name can be given. Specify 'none' if no external ip is desired.
|
|
external_projects (added in 2.4) |
no |
A list of other projects (accessible with the provisioning credentials) to be searched for the image.
|
||
image |
no | debian-8 |
image string to use for the instance (default will follow latest stable debian image)
|
|
image_family (added in 2.4) |
no |
image family from which to select the image. The most recent non-deprecated image in the family will be used.
|
||
instance_names |
no |
a comma-separated list of instance names to create or destroy
|
||
ip_forward (added in 1.9) |
no | false |
set to true if the instance can forward ip packets (useful for gateways)
|
|
machine_type |
no | n1-standard-1 |
machine type to use for the instance, use 'n1-standard-1' by default
|
|
metadata |
no |
a hash/dictionary of custom data for the instance; '{"key":"value", ...}'
|
||
name |
no |
either a name of a single instance or when used with 'num_instances', the base name of a cluster of nodes
aliases: base_name
|
||
network |
no | default |
name of the network, 'default' will be used if not specified
|
|
num_instances (added in 2.3) |
no |
can be used with 'name', specifies the number of nodes to provision using 'name' as a base name
|
||
pem_file (added in 1.5.1) |
no |
path to the pem file associated with the service account email This option is deprecated. Use 'credentials_file'.
|
||
persistent_boot_disk |
no | false |
if set, create the instance with a persistent boot disk
|
|
preemptible (added in 2.1) |
no | false |
if set to true, instances will be preemptible and time-limited. (requires libcloud >= 0.20.0)
|
|
project_id (added in 1.5.1) |
no |
your GCE project ID
|
||
service_account_email (added in 1.5.1) |
no |
service account email
|
||
service_account_permissions (added in 2.0) |
no |
|
service account permissions (see https://cloud.google.com/sdk/gcloud/reference/compute/instances/create, --scopes section for detailed information)
|
|
state |
no | present |
|
desired state of the resource
|
subnetwork (added in 2.2) |
no |
name of the subnetwork in which the instance should be created
|
||
tags |
no |
a comma-separated list of tags to associate with the instance
|
||
zone |
yes | us-central1-a |
the GCE zone to use. The list of available zones is at https://cloud.google.com/compute/docs/regions-zones/regions-zones#available.
|
# Basic provisioning example. Create a single Debian 8 instance in the # us-central1-a Zone of the n1-standard-1 machine type. # Create multiple instances by specifying multiple names, separated by # commas in the instance_names field # (e.g. my-test-instance1,my-test-instance2) gce: instance_names: my-test-instance1 zone: us-central1-a machine_type: n1-standard-1 image: debian-8 state: present service_account_email: "your-sa@your-project-name.iam.gserviceaccount.com" credentials_file: "/path/to/your-key.json" project_id: "your-project-name" disk_size: 32 # Create a single instance of an image from the "my-base-image" image family # in the us-central1-a Zone of the n1-standard-1 machine type. # This image family is in the "my-other-project" GCP project. gce: instance_names: my-test-instance1 zone: us-central1-a machine_type: n1-standard-1 image_family: my-base-image external_projects: - my-other-project state: present service_account_email: "your-sa@your-project-name.iam.gserviceaccount.com" credentials_file: "/path/to/your-key.json" project_id: "your-project-name" disk_size: 32 # Create a single Debian 8 instance in the us-central1-a Zone # Use existing disks, custom network/subnetwork, set service account permissions # add tags and metadata. gce: instance_names: my-test-instance zone: us-central1-a machine_type: n1-standard-1 state: present metadata: '{"db":"postgres", "group":"qa", "id":500}' tags: - http-server - my-other-tag disks: - name: disk-2 mode: READ_WRITE - name: disk-3 mode: READ_ONLY disk_auto_delete: false network: foobar-network subnetwork: foobar-subnetwork-1 preemptible: true ip_forward: true service_account_permissions: - storage-full - taskqueue - bigquery - https://www.googleapis.com/auth/ndev.clouddns.readwrite service_account_email: "your-sa@your-project-name.iam.gserviceaccount.com" credentials_file: "/path/to/your-key.json" project_id: "your-project-name" --- # Example Playbook - name: Compute Engine Instance Examples hosts: localhost vars: service_account_email: "your-sa@your-project-name.iam.gserviceaccount.com" credentials_file: "/path/to/your-key.json" project_id: "your-project-name" tasks: - name: create multiple instances # Basic provisioning example. Create multiple Debian 8 instances in the # us-central1-a Zone of n1-standard-1 machine type. gce: instance_names: test1,test2,test3 zone: us-central1-a machine_type: n1-standard-1 image: debian-8 state: present service_account_email: "{{ service_account_email }}" credentials_file: "{{ credentials_file }}" project_id: "{{ project_id }}" metadata : '{ "startup-script" : "apt-get update" }' register: gce - name: Save host data add_host: hostname: "{{ item.public_ip }}" groupname: gce_instances_ips with_items: "{{ gce.instance_data }}" - name: Wait for SSH for instances wait_for: delay: 1 host: "{{ item.public_ip }}" port: 22 state: started timeout: 30 with_items: "{{ gce.instance_data }}" - name: Configure Hosts hosts: gce_instances_ips become: yes become_method: sudo roles: - my-role-one - my-role-two tags: - config - name: delete test-instances # Basic termination of instance. gce: service_account_email: "{{ service_account_email }}" credentials_file: "{{ credentials_file }}" project_id: "{{ project_id }}" instance_names: "{{ gce.instance_names }}" zone: us-central1-a state: absent tags: - delete
Note
This module is flagged as preview which means that it is not guaranteed to have a backwards compatible interface.
For help in developing on modules, should you be so inclined, please read Community Information & Contributing, Testing Ansible and Developing Modules.