Rally provides a framework for performance analysis and benchmarking of individual OpenStack components as well as full production OpenStack cloud deployments
Go to file
Andrey Kurilin 1137e469f3 Ensure that we support py34,py36,py37 envs
This patch adds non-voting CI jobs for py34,py36,py37 envs. They will be
turned to the voting as soon as they become green.

Also, since configuration of zuul become bigger, it is moved to the
separate directory.

Change-Id: I2f9d526e769f37792db23242ef51e6bb703b2524
2018-08-07 13:04:07 +03:00
.zuul.d Ensure that we support py34,py36,py37 envs 2018-08-07 13:04:07 +03:00
devstack [evil][ci] Preparing to remove all OpenStack in-tree plugins 2018-06-13 16:01:00 +03:00
doc Fix minor typo in Rally Plugins doc 2018-07-11 00:25:56 -04:00
etc Add rally env cleanup command 2018-08-07 09:56:58 +00:00
rally Add rally env cleanup command 2018-08-07 09:56:58 +00:00
rally-jobs [evil] Remove OpenStack related plugins 2018-06-20 19:01:47 +03:00
samples [evil] Remove OpenStack related plugins 2018-06-20 19:01:47 +03:00
tests Ensure that we support py34,py36,py37 envs 2018-08-07 13:04:07 +03:00
.coveragerc [CI] Fix coverage job 2016-06-27 15:39:13 +03:00
.dockerignore Fix docker build command 2015-11-10 16:33:29 -08:00
.gitignore [ci] Start fixing CLI job 2017-10-12 12:13:18 +03:00
.gitreview Update .gitreview file to reflect repo rename 2015-04-18 00:37:36 +00:00
bindep.txt Update links in bindep.txt 2018-01-16 12:17:17 +08:00
CHANGELOG.rst Add rally env cleanup command 2018-08-07 09:56:58 +00:00
CONTRIBUTING.rst [docs][6] Re-design docs to cover all user-groups 2017-01-10 11:25:00 -08:00
Dockerfile Dockerfile - trivial fixes 2018-02-07 19:01:26 +00:00
install_rally.sh [install] Use constraints in install script 2018-01-14 14:50:29 +02:00
LICENSE Initial commit 2013-08-03 09:17:25 -07:00
optional-requirements.txt Fixing docker-check jenkins job 2016-09-20 16:56:00 +03:00
README.rst Prepare to Rally 1.0.0 release 2018-06-20 19:02:05 +03:00
requirements.txt [evil] Remove OpenStack related plugins 2018-06-20 19:01:47 +03:00
setup.cfg [cfg] Use stderr for logging by default 2018-02-14 19:31:27 +02:00
setup.py Updated from global requirements 2015-09-22 10:45:07 +00:00
test-requirements.txt Remove several test dependencies 2018-04-17 19:30:05 +03:00
tox.ini Ensure that we support py34,py36,py37 envs 2018-08-07 13:04:07 +03:00
upper-constraints.txt Fix the version of websocket-client 2018-02-27 16:06:57 +02:00

Rally

Rally is tool & framework that allows one to write simple plugins and combine them in complex tests scenarios that allows to perform all kinds of testing!

Team and repository tags

image

Latest Version

Gitter Chat

Trello Board

Apache License, Version 2.0

What is Rally

Rally is intended to provide a testing framework that is capable to perform specific, complicated and reproducible test cases on real deployment scenarios.

Rally workflow can be visualized by the following diagram:

Rally Architecture

Who Is Using Rally

Who is Using Rally

Documentation

Rally documentation on ReadTheDocs is a perfect place to start learning about Rally. It provides you with an easy and illustrative guidance through this benchmarking tool.

For example, check out the Rally step-by-step tutorial that explains, in a series of lessons, how to explore the power of Rally in benchmarking your OpenStack clouds.

Architecture

In terms of software architecture, Rally is built of 4 main components:

  1. Environment - one of key component in Rally. It manages and stores information about tested platforms. Env manager is using platform plugins to: create, delete, cleanup, check health, obtain information about platforms.
  2. Task component is responsible for executing tests defined in task specs, persisting and reporting results.
  3. Verification component allows to wrap subunit-based testing tools and provide complete tool on top of them with allow to do pre configuration, post cleanup as well process and persist results to Rally DB for future use like reporting and results comparing.

Use Cases

There are 3 major high level Rally Use Cases:

Rally Use Cases

Typical cases where Rally aims to help are:

  • Automate measuring & profiling focused on how new code changes affect the OpenStack performance;

  • Using Rally profiler to detect scaling & performance issues;

  • Investigate how different deployments affect the OS performance:

    • Find the set of suitable OpenStack deployment architectures;
    • Create deployment specifications for different loads (amount of controllers, swift nodes, etc.);
  • Automate the search for hardware best suited for particular OpenStack cloud;

  • Automate the production cloud specification generation:

    • Determine terminal loads for basic cloud operations: VM start & stop, Block Device create/destroy & various OpenStack API methods;
    • Check performance of basic cloud operations in case of different loads.