| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105 | .. _internals-task-message-protocol:======================= Task Message Protocol=======================.. contents::    :local:Message format==============* task    `string`    Name of the task. **required*** id    `string`    Unique id of the task (UUID). **required*** args    `list`    List of arguments. Will be an empty list if not provided.* kwargs    `dictionary`    Dictionary of keyword arguments. Will be an empty dictionary if not    provided.* retries    `int`    Current number of times this task has been retried.    Defaults to `0` if not specified.* eta    `string` (ISO 8601)    Estimated time of arrival. This is the date and time in ISO 8601    format. If not provided the message is not scheduled, but will be    executed asap.* expires (introduced after v2.0.2)    `string` (ISO 8601)    Expiration date. This is the date and time in ISO 8601 format.    If not provided the message will never expire. The message    will be expired when the message is received and the expiration date    has been exceeded.Extensions==========Extensions are additional keys in the message body that the worker may ormay not support.  If the worker finds an extension key it doesn't supportit should optimally reject the message so another worker gets a chanceto process it.* taskset_id  The taskset this task is part of.* chord  Siginifies that this task is one of the header parts of a chord.  The value  of this key is the body of the cord that should be executed when all of  the tasks in the header has returned.Example message===============This is an example invocation of the `celery.task.PingTask` task in JSONformat:.. code-block:: javascript    {"id": "4cc7438e-afd4-4f8f-a2f3-f46567e7ca77",     "task": "celery.task.PingTask",     "args": [],     "kwargs": {},     "retries": 0,     "eta": "2009-11-17T12:30:56.527191"}Serialization=============The protocol supports several serialization formats using the`content_type` message header.The MIME-types supported by default are shown in the following table.    =============== =================================         Scheme                 MIME Type    =============== =================================    json            application/json    yaml            application/x-yaml    pickle          application/x-python-serialize    msgpack         application/x-msgpack    =============== =================================
 |