| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119 | .. _guide-debugging:====================================== Debugging======================================.. _tut-remote_debug:Debugging Tasks Remotely (using pdb)====================================Basics------:mod:`celery.contrib.rdb` is an extended version of :mod:`pdb` thatenables remote debugging of processes that doesn't have terminalaccess.Example usage:.. code-block:: python    from celery import task    from celery.contrib import rdb    @task()    def add(x, y):        result = x + y        rdb.set_trace()  # <- set break-point        return result:func:`~celery.contrib.rdb.set_trace` sets a break-point at the currentlocation and creates a socket you can telnet into to remotely debugyour task.The debugger may be started by multiple processes at the same time,so rather than using a fixed port the debugger will search for anavailable port, starting from the base port (6900 by default).The base port can be changed using the environment variable:envvar:`CELERY_RDB_PORT`.By default the debugger will only be available from the local host,to enable access from the outside you have to set the environmentvariable :envvar:`CELERY_RDB_HOST`.When the worker encounters your break-point it'll log the followinginformation:.. code-block:: text    [INFO/MainProcess] Received task:        tasks.add[d7261c71-4962-47e5-b342-2448bedd20e8]    [WARNING/PoolWorker-1] Remote Debugger:6900:        Please telnet 127.0.0.1 6900.  Type `exit` in session to continue.    [2011-01-18 14:25:44,119: WARNING/PoolWorker-1] Remote Debugger:6900:        Waiting for client...If you telnet the port specified you'll be presentedwith a `pdb` shell:.. code-block:: console    $ telnet localhost 6900    Connected to localhost.    Escape character is '^]'.    > /opt/devel/demoapp/tasks.py(128)add()    -> return result    (Pdb)Enter ``help`` to get a list of available commands,It may be a good idea to read the `Python Debugger Manual`_ ifyou have never used `pdb` before.To demonstrate, we'll read the value of the ``result`` variable,change it and continue execution of the task:.. code-block:: text    (Pdb) result    4    (Pdb) result = 'hello from rdb'    (Pdb) continue    Connection closed by foreign host.The result of our vandalism can be seen in the worker logs:.. code-block:: text    [2011-01-18 14:35:36,599: INFO/MainProcess] Task        tasks.add[d7261c71-4962-47e5-b342-2448bedd20e8] succeeded        in 61.481s: 'hello from rdb'.. _`Python Debugger Manual`: http://docs.python.org/library/pdb.htmlTips----.. _breakpoint_signal:Enabling the break-point signal~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~If the environment variable :envvar:`CELERY_RDBSIG` is set, the workerwill open up an rdb instance whenever the `SIGUSR2` signal is sent.This is the case for both main and worker processes.For example starting the worker with:.. code-block:: console    $ CELERY_RDBSIG=1 celery worker -l infoYou can start an rdb session for any of the worker processes by executing:.. code-block:: console    $ kill -USR2 <pid>
 |