cs_instance – Manages instances and virtual machines on Apache CloudStack based clouds¶
Requirements¶
The below requirements are needed on the host that executes this module.
- python >= 2.6 
- cs >= 0.6.10 
Parameters¶
Notes¶
Note
- Ansible uses the - cslibrary’s configuration method if credentials are not provided by the arguments- api_url,- api_key,- api_secret. Configuration is read from several locations, in the following order. The- CLOUDSTACK_ENDPOINT,- CLOUDSTACK_KEY,- CLOUDSTACK_SECRETand- CLOUDSTACK_METHOD.- CLOUDSTACK_TIMEOUTenvironment variables. A- CLOUDSTACK_CONFIGenvironment variable pointing to an- .inifile. A- cloudstack.inifile in the current working directory. A- .cloudstack.inifile in the users home directory. Optionally multiple credentials and endpoints can be specified using ini sections in- cloudstack.ini. Use the argument- api_regionto select the section name, default section is- cloudstack. See https://github.com/exoscale/cs for more information.
- A detailed guide about cloudstack modules can be found in the CloudStack Cloud Guide. 
- This module supports check mode. 
Examples¶
# NOTE: Names of offerings and ISOs depending on the CloudStack configuration.
- name: create a instance from an ISO
  cs_instance:
    name: web-vm-1
    iso: Linux Debian 7 64-bit
    hypervisor: VMware
    project: Integration
    zone: ch-zrh-ix-01
    service_offering: 1cpu_1gb
    disk_offering: PerfPlus Storage
    disk_size: 20
    networks:
      - Server Integration
      - Sync Integration
      - Storage Integration
  delegate_to: localhost
- name: for changing a running instance, use the 'force' parameter
  cs_instance:
    name: web-vm-1
    display_name: web-vm-01.example.com
    iso: Linux Debian 7 64-bit
    service_offering: 2cpu_2gb
    force: yes
  delegate_to: localhost
# NOTE: user_data can be used to kickstart the instance using cloud-init yaml config.
- name: create or update a instance on Exoscale's public cloud using display_name.
  cs_instance:
    display_name: web-vm-1
    template: Linux Debian 7 64-bit
    service_offering: Tiny
    ssh_key: john@example.com
    tags:
      - key: admin
        value: john
      - key: foo
        value: bar
    user_data: |
        #cloud-config
        packages:
          - nginx
  delegate_to: localhost
- name: create an instance with multiple interfaces specifying the IP addresses
  cs_instance:
    name: web-vm-1
    template: Linux Debian 7 64-bit
    service_offering: Tiny
    ip_to_networks:
      - network: NetworkA
        ip: 10.1.1.1
      - network: NetworkB
        ip: 192.0.2.1
  delegate_to: localhost
- name: ensure an instance is stopped
  cs_instance:
    name: web-vm-1
    state: stopped
  delegate_to: localhost
- name: ensure an instance is running
  cs_instance:
    name: web-vm-1
    state: started
  delegate_to: localhost
- name: remove an instance
  cs_instance:
    name: web-vm-1
    state: absent
  delegate_to: localhost
Return Values¶
Common return values are documented here, the following are the fields unique to this module:
Status¶
- This module is guaranteed to have backward compatible interface changes going forward. [stableinterface] 
- This module is maintained by the Ansible Community. [community] 
Authors¶
- René Moser (@resmo) 
Hint
If you notice any issues in this documentation, you can edit this document to improve it.
