python - How can I set up Celery to call a custom initialization function before running my tasks? -


I have a dynamic project and I try to use celery to submit jobs for background processing () I am here. The celery integrates well with jigs and I am capable of submitting my custom tasks and getting the results back.

The only problem is that I can not find the sensible method of initializing customization in the daemon process. I have to call an expensive task that loads a lot of memory before processing the processing, and I I am not able to call that function every time.

Does anybody have this problem before? Any idea how to work it without modifying the cellular source code?

Thanks

You can write a custom loader or use a signal .

The loader has the on_task_init method, which is said to be executed when the task is executed, and the which is called the cellular + serial bit main process.

Using signals is the easiest, there are available signals:

0.8.x:

  • Task_progress (task_id, Work, args, quad)

    The worker has been dispatched to perform the work (or locally if applies / or if CELERY_ALWAYS_EAGER is set).

  • task_postrun (task_id, task, args, kwargs, retval) after one task has been executed in the above terms.

  • task_cent (task_id, task, args, kwargs, eta, taskset)

    When a task is applied (long Not enough till the time) Additional signals available in 0.95 (Current Master branch on Gitball):

    • Worker_init ()

      When the cellarid has started (before the work begins, so if there is a system supporting fork , any memory change child Will be copied to the worker process).

    • worker_ready ()

      Selereed is called to be able to get work.

    • worker_shutdown ()

      When the cell is off, the call is made.

    Here is an example of the first run in a Work for the first time:

      from celery.task import celery.registr task imports of Y Import Kren_sath_purw_prerkel_tel = {} class Paursoftio (task): def run (self-X): If _precalc_table X: return _precalc_table [x] else: return x ** 2 taskss.register (PowersOfTwo) Def _precalc_numbers ( ** kwargs): If not _precalc_table: # it is empty, so I was not born yet (1024) to the limit: _precalc_table [i] = i ** 2 # from the logic of Is required to use a registered instance. Task_prerun.connect (_precalc_numbers, from = function [PowerOfTwo.name])  

    If you want to run the function for all functions, just from Leave the argument.


  • Comments

    Popular posts from this blog

    php - multilevel menu with multilevel array -

    c# - TypeConverter in propertygrid only converts from string, not to -

    jQuery UI: Datepicker month format -