Ask Solem 830e216835 Stress: Use pyamqp:// by default 10 years ago
..
stress 830e216835 Stress: Use pyamqp:// by default 10 years ago
README.rst 8753e2c52e Update README.rst file to include CSTRESS_BROKER. 11 years ago
rabbit-restart-loop.sh a1e0896d65 Stresstests: Adds -J option to not join tasks 12 years ago

README.rst

=========================
Celery Stresstest Suite
=========================

.. contents::
:local:

Introduction
============

These tests will attempt to break the worker in different ways.

The worker must currently be started separately, and it's encouraged
to run the stresstest with different configuration values.

Ideas include:

1) Frequent maxtasksperchild, single process

::

$ celery -A stress worker -c 1 --maxtasksperchild=1

2) Frequent scale down & maxtasksperchild, single process

::

$ AUTOSCALE_KEEPALIVE=0.01 celery -A stress worker --autoscale=1,0 \
--maxtasksperchild=1

3) Frequent maxtasksperchild, multiple processes

::

$ celery -A stress worker -c 8 --maxtasksperchild=1``

4) Default, single process

::

$ celery -A stress worker -c 1

5) Default, multiple processes

::

$ celery -A stress worker -c 8

6) Processes termianted by time limits

::

$ celery -A stress worker --time-limit=1

7) Frequent maxtasksperchild, single process with late ack.

::

$ celery -A stress worker -c1 --maxtasksperchild=1 -Z acks_late


8) Worker using eventlet pool.

Start the worker::

$ celery -A stress worker -c1000 -P eventlet

Then must use the `-g green` test group::

$ python -m stress -g green

9) Worker using gevent pool.

It's also a good idea to include the ``--purge`` argument to clear out tasks from
previous runs.

Note that the stress client will probably hang if the test fails, so this
test suite is currently not suited for automatic runs.

Configuration Templates
-----------------------

You can select a configuration template using the `-Z` command-line argument
to any :program:`celery -A stress` command or the :program:`python -m stress`
command when running the test suite itself.

The templates available are:

* default

Using amqp as a broker and rpc as a result backend,
and also using json for task and result messages.

* redis

Using redis as a broker and result backend

* acks_late

Enables late ack globally.

* pickle

Using pickle as the serializer for tasks and results
(also allowing the worker to receive and process pickled messages)


You can see the resulting configuration from any template by running
the command::

$ celery -A stress report -Z redis


Example running the stress test using the ``redis`` configuration template::

$ python -m stress -Z redis

Example running the worker using the ``redis`` configuration template::

$ celery -A stress worker -Z redis


You can also mix several templates by listing them separated by commas::

$ celery -A stress worker -Z redis,acks_late

In this example (``redis,acks_late``) the ``redis`` template will be used
as a configuration, and then additional keys from the ``acks_late`` template
will be added on top as changes::

$ celery -A stress report -Z redis,acks_late,pickle

Running the client
------------------

After the worker is running you can start the client to run the complete test
suite::

$ python -m stress

You can also specify which tests to run:

$ python -m stress revoketermfast revoketermslow

Or you can start from an offset, e.g. to skip the two first tests use
``--offset=2``::

$ python -m stress --offset=2

See ``python -m stress --help`` for a list of all available options.


Options
=======

Using a different broker
------------------------
You can set the environment ``CSTRESS_BROKER`` to change the broker used::

$ CSTRESS_BROKER='amqp://' celery -A stress worker # …
$ CSTRESS_BROKER='amqp://' python -m stress

Using a different result backend
--------------------------------

You can set the environment variable ``CSTRESS_BACKEND`` to change
the result backend used::

$ CSTRESS_BACKEND='amqp://' celery -A stress worker # …
$ CSTRESS_BACKEND='amqp://' python -m stress

Using a custom queue
--------------------

A queue named ``c.stress`` is created and used by default,
but you can change the name of this queue using the ``CSTRESS_QUEUE``
environment variable.