18dd391ae9
The __future__ module [1] was used in this context to ensure compatibility between python 2 and python 3. We previously dropped the support of python 2.7 [2] and now we only support python 3 so we don't need to continue to use this module and the imports listed below. Imports commonly used and their related PEPs: - `division` is related to PEP 238 [3] - `print_function` is related to PEP 3105 [4] - `unicode_literals` is related to PEP 3112 [5] - `with_statement` is related to PEP 343 [6] - `absolute_import` is related to PEP 328 [7] [1] https://docs.python.org/3/library/__future__.html [2] https://governance.openstack.org/tc/goals/selected/ussuri/drop-py27.html [3] https://www.python.org/dev/peps/pep-0238 [4] https://www.python.org/dev/peps/pep-3105 [5] https://www.python.org/dev/peps/pep-3112 [6] https://www.python.org/dev/peps/pep-0343 [7] https://www.python.org/dev/peps/pep-0328 Change-Id: I0b77453c1b8436a5057d1cd33d7f3d5a28f7c394 |
||
---|---|---|
.. | ||
README.rst | ||
rolling_restart.py | ||
rolling_tests.py |
Bowling Ball - OpenStack-Ansible Rolling Downtime Simulator
- date
-
2017-03-09
- tags
-
rackspace, openstack, ansible
- category
-
*openstack, *nix
About
This project aims to test for issues with rolling downtime on OpenStack-Ansible deployments. It's comprised of two main components:
- The
rolling_restart.py
script - The
rolling_test.py
script
The rolling_restart.py
script will stop containers from
a specified group in a rolling fashion - node 1 will stop, then start,
then node 2, then node 3 and so on. This script runs from the
deployment host.
The tests
directory contains scripts to generate traffic
against the target services. system that will be restarted by
rolling_restart.py
in order to measure the effects. These
scripts run from a utility container.
The rolling_test.py
script contains tests to generate
traffic against the target services. These vary per service, but attempt
to apply usage to a system that will be restarted by
rolling_restart.py
in order to measure the effects. This
script runs from a utility container.
Usage
Start your test from a utility container.
./rolling_test.py keystone
runs the Keystone test../rolling_test.py list
will list tests and their descriptionsFrom the deployment node, run
rolling_restart.py
in the playbooks directory (necessary to find the inventory script). Specify the service you're targeting with the-s
parameter.rolling_restart.py -s keystone_container
You can specify a wait time in seconds between stopping and starting individual nodes.
rolling_restart.py -s keystone_container -w 60
Assumptions
These tools are currently coupled to OSA, and they assume paths to
files as specified by the multi-node-aio
scripts.
Container stopping and starting is done with an ansible command, and the physical host to target is derived from the current inventory.
rolling_restart.py
must currently be run from the
playbooks
directory. This will be fixed later.
You must source openrc
before running
rolling_test.py
.
Creating New Tests
Tests should subclass from the ServiceTest
class in the
same file and implement the following properties and methods:
run
- The actual test to run should be placed in this method. Timings-
will be gathered based on when this function starts and stops.
pre_test
- Any pre-test setup that needs to happen, like creating a-
file for Glance, Cinder, or Swift upload.
post_test
- Any post-test teardown that might be needed.service_name
- The primary service that is being tested.description
- Brief description of what the test does.
Finally, add the test to the available_tests
dictionary
with the invocation name as the key and the class as the value.
Why the name?
It sets 'em up and knocks em down.