Create aggregates add host and boots a servers
This PR creates specified num_availabilty_zones and boots specified num of vms per availability zone Change-Id: I43dbef5f3248b705c157cf47751959918c826740
This commit is contained in:
parent
99512c928e
commit
5f60b1a346
|
@ -407,6 +407,22 @@ workloads:
|
|||
file: rally/octavia/octavia-create-delete-pools.yml
|
||||
sla_max_failure: 0
|
||||
|
||||
- name: availability-zone-boot-servers
|
||||
enabled: false
|
||||
type: rally
|
||||
rally_deployment: overcloud
|
||||
concurrency:
|
||||
- 1
|
||||
times: 1
|
||||
scenarios:
|
||||
- name: create-aggregate-nova-boot
|
||||
enabled: true
|
||||
image_name: cirro5
|
||||
flavor_name: m1.tiny-cirros
|
||||
num_availability_zones: 3
|
||||
num_vms_per_az: 10
|
||||
file: rally/rally-plugins/nova/create_aggregate_add_host_boot.yml
|
||||
|
||||
- name: simple-plugins
|
||||
enabled: false
|
||||
type: rally
|
||||
|
|
|
@ -0,0 +1,67 @@
|
|||
# Licensed under the Apache License, Version 2.0 (the "License");
|
||||
# you may not use this file except in compliance with the License.
|
||||
# You may obtain a copy of the License at
|
||||
#
|
||||
# http://www.apache.org/licenses/LICENSE-2.0
|
||||
#
|
||||
# Unless required by applicable law or agreed to in writing, software
|
||||
# distributed under the License is distributed on an "AS IS" BASIS,
|
||||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
# See the License for the specific language governing permissions and
|
||||
# limitations under the License.
|
||||
|
||||
from rally import exceptions
|
||||
from rally_openstack.common import consts
|
||||
from rally_openstack.task.scenarios.nova import utils as nova_utils
|
||||
from rally.task import scenario
|
||||
from rally.task import types
|
||||
from rally.task import validation
|
||||
|
||||
|
||||
@types.convert(image={"type": "glance_image"}, flavor={"type": "nova_flavor"})
|
||||
@validation.add("image_valid_on_flavor", flavor_param="flavor", image_param="image")
|
||||
@validation.add("required_services", services=[consts.Service.NOVA])
|
||||
@validation.add("required_platform", platform="openstack", users=True)
|
||||
@scenario.configure(context={"admin_cleanup@openstack": ["nova"], "cleanup@openstack": ["nova"]},
|
||||
name="BrowbeatPlugin.create_aggregate_add_host_boot_servers",
|
||||
platform="openstack")
|
||||
class CreateAggregateAddHostNovaBoot(nova_utils.NovaScenario):
|
||||
def run(self, image, flavor, num_availability_zones, metadata, num_vms_per_az, **kwargs):
|
||||
"""Create availability zones and boot servers
|
||||
|
||||
:param image: image ID or instance for server creation
|
||||
:param flavor: flavor ID or flavor name
|
||||
:param num_availability_zones: number of availability zones
|
||||
:param metadata: The metadata to be set as flavor extra specs
|
||||
:param num_vms_per_az: int, number of vm's per availability zone
|
||||
:param kwargs: other optional parameters to initialize the server
|
||||
"""
|
||||
list_aggregates = self._list_aggregates()
|
||||
aggregates = []
|
||||
for az in range(num_availability_zones):
|
||||
az_name = "region" + str(az)
|
||||
aggregates.append(self._create_aggregate(az_name))
|
||||
|
||||
hosts = self._list_hypervisors()
|
||||
host_names = set()
|
||||
for host in hosts:
|
||||
if (
|
||||
host.state == "up" and
|
||||
host.status == "enabled"
|
||||
):
|
||||
for aggregate in aggregates:
|
||||
if host.id not in aggregate.hosts:
|
||||
host_names.add(host.service["host"])
|
||||
|
||||
if not host_names:
|
||||
raise exceptions.RallyException("Could not find an available host")
|
||||
else:
|
||||
for j in range(len(host_names)):
|
||||
k = j % len(aggregates)
|
||||
self._aggregate_set_metadata(aggregates[k], metadata)
|
||||
self._aggregate_add_host(aggregates[k], list(host_names)[j])
|
||||
|
||||
for _ in range(num_vms_per_az):
|
||||
for availability_zone in aggregates:
|
||||
kwargs["availability-zone"] = availability_zone
|
||||
self._boot_server(image, flavor, **kwargs)
|
|
@ -0,0 +1,42 @@
|
|||
{% set image_name = image_name or 'cirros' %}
|
||||
{% set flavor_name = flavor_name or 'm1.xtiny' %}
|
||||
{% set num_availability_zones = num_availability_zones or 3 %}
|
||||
{% set num_vms_per_az = num_vms_per_az or 10 %}
|
||||
{% set sla_max_avg_duration = sla_max_avg_duration or 60 %}
|
||||
{% set sla_max_failure = sla_max_failure or 0 %}
|
||||
{% set sla_max_seconds = sla_max_seconds or 60 %}
|
||||
---
|
||||
BrowbeatPlugin.create_aggregate_add_host_boot_servers:
|
||||
-
|
||||
args:
|
||||
flavor:
|
||||
name: '{{flavor_name}}'
|
||||
image:
|
||||
name: '{{image_name}}'
|
||||
num_availability_zones: {{num_availability_zones}}
|
||||
num_vms_per_az: {{num_vms_per_az}}
|
||||
metadata:
|
||||
test_metadata: "true"
|
||||
runner:
|
||||
concurrency: {{concurrency}}
|
||||
times: {{times}}
|
||||
type: 'constant'
|
||||
context:
|
||||
users:
|
||||
tenants: 1
|
||||
users_per_tenant: 8
|
||||
quotas:
|
||||
neutron:
|
||||
network: -1
|
||||
port: -1
|
||||
router: -1
|
||||
subnet: -1
|
||||
nova:
|
||||
instances: -1
|
||||
cores: -1
|
||||
ram: -1
|
||||
sla:
|
||||
max_avg_duration: {{sla_max_avg_duration}}
|
||||
max_seconds_per_iteration: {{sla_max_seconds}}
|
||||
failure_rate:
|
||||
max: {{sla_max_failure}}
|
Loading…
Reference in New Issue