GCE module examples update. Correct syntax, demonstrate other options and creation of multiple instances. (#5192)
This commit is contained in:
parent
810040be05
commit
72635db94d
1 changed files with 91 additions and 79 deletions
|
@ -23,7 +23,7 @@ version_added: "1.4"
|
||||||
short_description: create or terminate GCE instances
|
short_description: create or terminate GCE instances
|
||||||
description:
|
description:
|
||||||
- Creates or terminates Google Compute Engine (GCE) instances. See
|
- Creates or terminates Google Compute Engine (GCE) instances. See
|
||||||
U(https://cloud.google.com/products/compute-engine) for an overview.
|
U(https://cloud.google.com/compute) for an overview.
|
||||||
Full install/configuration instructions for the gce* modules can
|
Full install/configuration instructions for the gce* modules can
|
||||||
be found in the comments of ansible/test/gce_tests.py.
|
be found in the comments of ansible/test/gce_tests.py.
|
||||||
options:
|
options:
|
||||||
|
@ -95,7 +95,8 @@ options:
|
||||||
aliases: []
|
aliases: []
|
||||||
name:
|
name:
|
||||||
description:
|
description:
|
||||||
- identifier when working with a single instance
|
- identifier when working with a single instance. Will be deprecated in a future release.
|
||||||
|
Please 'instance_names' instead.
|
||||||
required: false
|
required: false
|
||||||
aliases: []
|
aliases: []
|
||||||
network:
|
network:
|
||||||
|
@ -177,96 +178,107 @@ requirements:
|
||||||
- "apache-libcloud >= 0.13.3, >= 0.17.0 if using JSON credentials,
|
- "apache-libcloud >= 0.13.3, >= 0.17.0 if using JSON credentials,
|
||||||
>= 0.20.0 if using preemptible option"
|
>= 0.20.0 if using preemptible option"
|
||||||
notes:
|
notes:
|
||||||
- Either I(name) or I(instance_names) is required.
|
- Either I(instance_names) or I(name) is required.
|
||||||
author: "Eric Johnson (@erjohnso) <erjohnso@google.com>"
|
- JSON credentials strongly preferred.
|
||||||
|
author: "Eric Johnson (@erjohnso) <erjohnso@google.com>, Tom Melendez (@supertom) <supertom@google.com>"
|
||||||
'''
|
'''
|
||||||
|
|
||||||
EXAMPLES = '''
|
EXAMPLES = '''
|
||||||
# Basic provisioning example. Create a single Debian 7 instance in the
|
# Basic provisioning example. Create a single Debian 8 instance in the
|
||||||
# us-central1-a Zone of n1-standard-1 machine type.
|
# us-central1-a Zone of the n1-standard-1 machine type.
|
||||||
- local_action:
|
# Create multiple instances by specifying multiple names, seperated by
|
||||||
module: gce
|
# commas in the instance_names field
|
||||||
name: test-instance
|
# (e.g. my-test-instance1,my-test-instance2)
|
||||||
zone: us-central1-a
|
gce:
|
||||||
machine_type: n1-standard-1
|
instance_names: my-test-instance1
|
||||||
image: debian-7
|
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"
|
||||||
|
|
||||||
# Example using defaults and with metadata to create a single 'foo' instance
|
# Create a single Debian 8 instance in the us-central1-a Zone
|
||||||
- local_action:
|
# Use existing disks, custom network/subnetwork, set service account permissions
|
||||||
module: gce
|
# add tags and metadata.
|
||||||
name: foo
|
gce:
|
||||||
metadata: '{"db":"postgres", "group":"qa", "id":500}'
|
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
|
||||||
|
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
|
||||||
# Launch instances from a control node, runs some tasks on the new instances,
|
- name: Compute Engine Instance Examples
|
||||||
# and then terminate them
|
|
||||||
# This example uses JSON credentials with the credentials_file parameter
|
|
||||||
# rather than the deprecated pem_file option with PEM formatted credentials.
|
|
||||||
|
|
||||||
- name: Create a sandbox instance
|
|
||||||
hosts: localhost
|
hosts: localhost
|
||||||
vars:
|
vars:
|
||||||
names: foo,bar
|
service_account_email: "your-sa@your-project-name.iam.gserviceaccount.com"
|
||||||
machine_type: n1-standard-1
|
credentials_file: "/path/to/your-key.json"
|
||||||
image: debian-6
|
project_id: "your-project-name"
|
||||||
zone: us-central1-a
|
|
||||||
service_account_email: unique-email@developer.gserviceaccount.com
|
|
||||||
credentials_file: /path/to/json_file
|
|
||||||
project_id: project-id
|
|
||||||
tasks:
|
tasks:
|
||||||
- name: Launch instances
|
- name: create multiple instances
|
||||||
local_action: gce instance_names={{names}} machine_type={{machine_type}}
|
# Basic provisioning example. Create multiple Debian 8 instances in the
|
||||||
image={{image}} zone={{zone}}
|
# us-central1-a Zone of n1-standard-1 machine type.
|
||||||
service_account_email={{ service_account_email }}
|
gce:
|
||||||
credentials_file={{ credentials_file }}
|
instance_names: test1,test2,test3
|
||||||
project_id={{ project_id }}
|
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
|
register: gce
|
||||||
- name: Wait for SSH to come up
|
|
||||||
local_action: wait_for host={{item.public_ip}} port=22 delay=10
|
|
||||||
timeout=60 state=started
|
|
||||||
with_items: {{gce.instance_data}}
|
|
||||||
|
|
||||||
- name: Configure instance(s)
|
- name: Save host data
|
||||||
hosts: launched
|
add_host: hostname={{ item.public_ip }} groupname=gce_instances_ips
|
||||||
sudo: True
|
with_items: "{{ gce.instance_data }}"
|
||||||
roles:
|
|
||||||
- my_awesome_role
|
|
||||||
- my_awesome_tasks
|
|
||||||
|
|
||||||
- name: Terminate instances
|
- name: Wait for SSH for instances
|
||||||
hosts: localhost
|
wait_for: delay=1 host={{ item.public_ip }} port=22 state=started timeout=30
|
||||||
connection: local
|
with_items: "{{ gce.instance_data }}"
|
||||||
tasks:
|
|
||||||
- name: Terminate instances that were previously launched
|
|
||||||
local_action:
|
|
||||||
module: gce
|
|
||||||
state: 'absent'
|
|
||||||
instance_names: {{gce.instance_names}}
|
|
||||||
|
|
||||||
# The deprecated PEM file credentials can be used as follows
|
- name: Configure Hosts
|
||||||
- name: Create a sandbox instance with PEM credentials
|
hosts: gce_instances_ips
|
||||||
hosts: localhost
|
become: yes
|
||||||
vars:
|
become_method: sudo
|
||||||
names: foo,bar
|
roles:
|
||||||
machine_type: n1-standard-1
|
- my-role-one
|
||||||
image: debian-6
|
- my-role-two
|
||||||
zone: us-central1-a
|
tags:
|
||||||
service_account_email: unique-email@developer.gserviceaccount.com
|
- config
|
||||||
pem_file: /path/to/pem_file
|
|
||||||
project_id: project-id
|
|
||||||
tasks:
|
|
||||||
- name: Launch instances
|
|
||||||
local_action: gce instance_names={{names}} machine_type={{machine_type}}
|
|
||||||
image={{image}} zone={{zone}}
|
|
||||||
service_account_email={{ service_account_email }}
|
|
||||||
pem_file={{ pem_file }}
|
|
||||||
project_id={{ project_id }}
|
|
||||||
register: gce
|
|
||||||
- name: Wait for SSH to come up
|
|
||||||
local_action: wait_for host={{item.public_ip}} port=22 delay=10
|
|
||||||
timeout=60 state=started
|
|
||||||
with_items: {{gce.instance_data}}
|
|
||||||
|
|
||||||
|
- 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
|
||||||
'''
|
'''
|
||||||
|
|
||||||
import socket
|
import socket
|
||||||
|
|
Loading…
Reference in a new issue