On this page
ngine_io.cloudstack.cs_service_offering – Manages service offerings on Apache CloudStack based clouds.
Note
This plugin is part of the ngine_io.cloudstack collection (version 2.2.2).
You might already have this collection installed if you are using the ansible
package. It is not included in ansible-core
. To check whether it is installed, run ansible-galaxy collection list
.
To install it, use: ansible-galaxy collection install ngine_io.cloudstack
.
To use it in a playbook, specify: ngine_io.cloudstack.cs_service_offering
.
New in version 0.1.0: of ngine_io.cloudstack
Synopsis
- Create and delete service offerings for guest and system VMs.
- Update display_text of existing service offering.
Requirements
The below requirements are needed on the host that executes this module.
- python >= 2.6
- cs >= 0.9.0
Parameters
Parameter | Choices/Defaults | Comments |
---|---|---|
api_http_method
string
|
|
HTTP method used to query the API endpoint.
If not given, the CLOUDSTACK_METHOD env variable is considered.
|
api_key
string / required
|
API key of the CloudStack API.
If not given, the CLOUDSTACK_KEY env variable is considered.
|
|
api_secret
string / required
|
Secret key of the CloudStack API.
If not set, the CLOUDSTACK_SECRET env variable is considered.
|
|
api_timeout
integer
|
Default:
10
|
HTTP timeout in seconds.
If not given, the CLOUDSTACK_TIMEOUT env variable is considered.
|
api_url
string / required
|
URL of the CloudStack API e.g. https://cloud.example.com/client/api.
If not given, the CLOUDSTACK_ENDPOINT env variable is considered.
|
|
api_verify_ssl_cert
string
|
Verify CA authority cert file.
If not given, the CLOUDSTACK_VERIFY env variable is considered.
|
|
cpu_number
integer
|
The number of CPUs of the service offering.
|
|
cpu_speed
integer
|
The CPU speed of the service offering in MHz.
|
|
deployment_planner
string
|
The deployment planner heuristics used to deploy a VM of this offering.
If not set, the value of global config vm.deployment.planner is used.
|
|
disk_bytes_read_rate
integer
|
Bytes read rate of the disk offering.
aliases: bytes_read_rate |
|
disk_bytes_write_rate
integer
|
Bytes write rate of the disk offering.
aliases: bytes_write_rate |
|
disk_iops_max
integer
|
Max. iops of the compute offering.
|
|
disk_iops_min
integer
|
Min. iops of the compute offering.
|
|
disk_iops_read_rate
integer
|
IO requests read rate of the disk offering.
|
|
disk_iops_write_rate
integer
|
IO requests write rate of the disk offering.
|
|
display_text
string
|
Display text of the service offering.
If not set, name will be used as display_text while creating.
|
|
domain
string
|
Domain the service offering is related to.
Public for all domains and subdomains if not set.
|
|
host_tags
list / elements=string
|
The host tags for this service offering.
aliases: host_tag |
|
hypervisor_snapshot_reserve
integer
|
Hypervisor snapshot reserve space as a percent of a volume.
Only for managed storage using Xen or VMware.
|
|
is_customized
boolean
|
|
Whether the offering is customizable or not.
|
is_iops_customized
boolean
|
|
Whether compute offering iops is custom or not.
aliases: disk_iops_customized |
is_system
boolean
|
|
Whether it is a system VM offering or not.
|
is_volatile
boolean
|
|
Whether the virtual machine needs to be volatile or not.
Every reboot of VM the root disk is detached then destroyed and a fresh root disk is created and attached to VM.
|
limit_cpu_usage
boolean
|
|
Restrict the CPU usage to committed service offering.
|
memory
integer
|
The total memory of the service offering in MB.
|
|
name
string / required
|
Name of the service offering.
|
|
network_rate
integer
|
Data transfer rate in Mb/s allowed.
Supported only for non-system offering and system offerings having system_vm_type=domainrouter.
|
|
offer_ha
boolean
|
|
Whether HA is set for the service offering.
|
provisioning_type
string
|
|
Provisioning type used to create volumes.
|
service_offering_details
list / elements=dictionary
|
Details for planner, used to store specific parameters.
A list of dictionaries having keys key and value .
|
|
state
string
|
|
State of the service offering.
|
storage_tags
list / elements=string
|
The storage tags for this service offering.
aliases: storage_tag |
|
storage_type
string
|
|
The storage type of the service offering.
|
system_vm_type
string
|
|
The system VM type.
Required if is_system=yes.
|
Notes
Note
- A detailed guide about cloudstack modules can be found in the CloudStack Cloud Guide.
- This module supports check mode.
Examples
- name: Create a non-volatile compute service offering with local storage
ngine_io.cloudstack.cs_service_offering:
name: Micro
display_text: Micro 512mb 1cpu
cpu_number: 1
cpu_speed: 2198
memory: 512
host_tags: eco
storage_type: local
- name: Create a volatile compute service offering with shared storage
ngine_io.cloudstack.cs_service_offering:
name: Tiny
display_text: Tiny 1gb 1cpu
cpu_number: 1
cpu_speed: 2198
memory: 1024
storage_type: shared
is_volatile: yes
host_tags: eco
storage_tags: eco
- name: Create or update a volatile compute service offering with shared storage
ngine_io.cloudstack.cs_service_offering:
name: Tiny
display_text: Tiny 1gb 1cpu
cpu_number: 1
cpu_speed: 2198
memory: 1024
storage_type: shared
is_volatile: yes
host_tags: eco
storage_tags: eco
- name: Create or update a custom compute service offering
ngine_io.cloudstack.cs_service_offering:
name: custom
display_text: custom compute offer
is_customized: yes
storage_type: shared
host_tags: eco
storage_tags: eco
- name: Remove a compute service offering
ngine_io.cloudstack.cs_service_offering:
name: Tiny
state: absent
- name: Create or update a system offering for the console proxy
ngine_io.cloudstack.cs_service_offering:
name: System Offering for Console Proxy 2GB
display_text: System Offering for Console Proxy 2GB RAM
is_system: yes
system_vm_type: consoleproxy
cpu_number: 1
cpu_speed: 2198
memory: 2048
storage_type: shared
storage_tags: perf
- name: Remove a system offering
ngine_io.cloudstack.cs_service_offering:
name: System Offering for Console Proxy 2GB
is_system: yes
state: absent
Return Values
Common return values are documented here, the following are the fields unique to this module:
Key | Returned | Description |
---|---|---|
cpu_number
integer
|
success |
Number of CPUs in the service offering
Sample:
4
|
cpu_speed
integer
|
success |
Speed of CPUs in MHz in the service offering
Sample:
2198
|
created
string
|
success |
Date the offering was created
Sample:
2017-11-19T10:48:59+0000
|
disk_bytes_read_rate
integer
|
success |
Bytes read rate of the service offering
Sample:
1000
|
disk_bytes_write_rate
integer
|
success |
Bytes write rate of the service offering
Sample:
1000
|
disk_iops_max
integer
|
success |
Max iops of the disk offering
Sample:
1000
|
disk_iops_min
integer
|
success |
Min iops of the disk offering
Sample:
500
|
disk_iops_read_rate
integer
|
success |
IO requests per second read rate of the service offering
Sample:
1000
|
disk_iops_write_rate
integer
|
success |
IO requests per second write rate of the service offering
Sample:
1000
|
display_text
string
|
success |
Display text of the offering
Sample:
Micro 512mb 1cpu
|
domain
string
|
success |
Domain the offering is into
Sample:
ROOT
|
host_tags
list / elements=string
|
success |
List of host tags
Sample:
['eco']
|
id
string
|
success |
UUID of the service offering
Sample:
a6f7a5fc-43f8-11e5-a151-feff819cdc9f
|
is_customized
boolean
|
success |
Whether the offering is customizable or not
|
is_iops_customized
boolean
|
success |
Whether the offering uses custom IOPS or not
|
is_system
boolean
|
success |
Whether the offering is for system VMs or not
|
is_volatile
boolean
|
success |
Whether the offering is volatile or not
|
limit_cpu_usage
boolean
|
success |
Whether the CPU usage is restricted to committed service offering
|
memory
integer
|
success |
Memory of the system offering
Sample:
512
|
name
string
|
success |
Name of the system offering
Sample:
Micro
|
network_rate
integer
|
success |
Data transfer rate in megabits per second allowed
Sample:
1000
|
offer_ha
boolean
|
success |
Whether HA support is enabled in the offering or not
|
provisioning_type
string
|
success |
Provisioning type used to create volumes
Sample:
thin
|
service_offering_details
dictionary
|
success |
Additioanl service offering details
Sample:
{'vgpuType': 'GRID K180Q','pciDevice':'Group of NVIDIA Corporation GK107GL [GRID K1] GPUs'}
|
storage_tags
list / elements=string
|
success |
List of storage tags
Sample:
['eco']
|
storage_type
string
|
success |
Storage type used to create volumes
Sample:
shared
|
system_vm_type
string
|
success |
System VM type of this offering
Sample:
consoleproxy
|
Authors
- René Moser (@resmo)
© 2012–2018 Michael DeHaan
© 2018–2021 Red Hat, Inc.
Licensed under the GNU General Public License version 3.
https://docs.ansible.com/ansible/latest/collections/ngine_io/cloudstack/cs_service_offering_module.html