File: monitor.rst

package info (click to toggle)
django-q 1.8.0-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 1,276 kB
  • sloc: python: 5,686; makefile: 181; sh: 30
file content (189 lines) | stat: -rw-r--r-- 5,119 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
Monitor
=======
.. py:currentmodule::django_q.monitor


.. warning::
    Blessed needs to be installed to get this to work! See: https://pypi.org/project/blessed/


The cluster monitor shows live information about all the Q clusters connected to your project.

Start the monitor with Django's `manage.py` command::

    $ python manage.py qmonitor


.. image:: _static/monitor.png

For all broker types except the Redis broker, the monitor utilizes Django's cache framework to store statistics of running clusters.
This can be any type of cache backend as long as it can be shared among Django instances. For this reason, the local memory backend will not work.


Legend
------

Host
~~~~

Shows the hostname of the server this cluster is running on.

Id
~~

The cluster Id. Same as the cluster process ID or pid.

State
~~~~~

Current state of the cluster:

- **Starting** The cluster is spawning workers and getting ready.
- **Idle** Everything is ok, but there are no tasks to process.
- **Working** Processing tasks like a good cluster should.
- **Stopping** The cluster does not take on any new tasks and is finishing.
- **Stopped** All tasks have been processed and the cluster is shutting down.

Pool
~~~~

The current number of workers in the cluster pool.

TQ
~~

**Task Queue** counts the number of tasks in the queue [#f1]_

If this keeps rising it means you are taking on more tasks than your cluster can handle.
You can limit this by settings the :ref:`queue_limit` in your cluster configuration, after which it will turn green when that limit has been reached.
If your task queue is always hitting its limit and your running out of resources, it may be time to add another cluster.

RQ
~~

**Result Queue** shows the number of results in the queue. [#f1]_

Since results are only saved by a single process which has to access the database.
It's normal for the result queue to take slightly longer to clear than the task queue.

RC
~~

**Reincarnations** shows the amount of processes that have been reincarnated after a recycle, sudden death or timeout.
If this number is unusually high, you are either suffering from repeated task errors or severe timeouts and you should check your logs for details.

Up
~~

**Uptime** the amount of time that has passed since the cluster was started.


.. centered:: Press `q` to quit the monitor and return to your terminal.

Info
----

If you just want to see a one-off summary of your cluster stats you can use the `qinfo` management command::

    $ python manage.py qinfo


.. image:: _static/info.png

All stats are summed over all available clusters.

Task rate is calculated over the last 24 hours and will show the number of tasks per second, minute, hour or day depending on the amount.
Average execution time (`Avg time`) is calculated in seconds over the last 24 hours.

Since some of these numbers are based on what is available in your tasks database, limiting or disabling the result backend will skew them.

Like with the monitor, these statistics come from a Redis server or Django's cache framework. So make sure you have either one configured.

To print out the current configuration run::

    $ python manage.py qinfo --config


Status
------

You can check the status of your clusters straight from your code with the :class:`Stat` class:

.. code:: python

    from django_q.status import Stat

    for stat in Stat.get_all():
        print(stat.cluster_id, stat.status)

    # or if you know the cluster id
    cluster_id = 1234
    stat = Stat.get(cluster_id)
    print(stat.status, stat.workers)

Reference
---------

.. py:class:: Stat

   Cluster status object.

    .. py:attribute:: cluster_id

    Id of this cluster. Corresponds with the process id.

    .. py:attribute:: tob

    Time Of Birth

    .. py:method:: uptime

    Shows the number of seconds passed since the time of birth

    .. py:attribute:: reincarnations

    The number of times the sentinel had to start a new worker process.

    .. py:attribute:: status

    String representing the current cluster status.

    .. py:attribute:: task_q_size

    The number of tasks currently in the task queue. [#f1]_

    .. py:attribute:: done_q_size

    The number of tasks currently in the result queue. [#f1]_

    .. py:attribute:: pusher

    The pid of the pusher process

    .. py:attribute:: monitor

    The pid of the monitor process

    .. py:attribute:: sentinel

    The pid of the sentinel process

    .. py:attribute:: workers

    A list of process ids of the workers currently in the cluster pool.

    .. py:method:: empty_queues

    Returns true or false depending on any tasks still present in the task or result queue.

    .. py:classmethod:: get(cluster_id, broker=None)

    Gets the current :class:`Stat` for the cluster id. Takes an optional broker connection.

    .. py:classmethod:: get_all(broker=None)

    Returns a list of :class:`Stat` objects for all active clusters. Takes an optional broker connection.

.. rubric:: Footnotes

.. [#f1] Uses :meth:`multiprocessing.Queue.qsize()` which is not implemented on OS X and always returns 0.