pypi celery 5.5.0
v5.5.0

4 days ago

Celery v5.5.0 is now available.

Key Highlights

See What's new in Celery 5.5 for a complete overview or read the main highlights below.

Redis Broker Stability Improvements

Long-standing disconnection issues with the Redis broker have been identified and resolved in Kombu 5.5.0, which is included with this release. These improvements significantly enhance stability when using Redis as a broker.

Additionally, the Redis backend now has better exception handling with the new exception_safe_to_retry feature, which improves resilience during temporary Redis connection issues. See Redis backend settings for complete documentation.

Contributed by @drienkop in #9614.

pycurl replaced with urllib3

Replaced the pycurl dependency with urllib3.

We're monitoring the performance impact of this change and welcome feedback from users who notice any significant differences in their environments.

Contributed by @spawn-guy in Kombu #2134 and integrated in Celery via #9526.

RabbitMQ Quorum Queues Support

Added support for RabbitMQ's new Quorum Queues feature, including compatibility with ETA tasks. This implementation has some limitations compared to classic queues, so please refer to the documentation for details.

Native Delayed Delivery is automatically enabled when quorum queues are detected to implement the ETA mechanism.

See Using Quorum Queues for complete documentation.

Configuration options:

  • broker_native_delayed_delivery_queue_type: Specifies the queue type for delayed delivery (default: quorum)
  • task_default_queue_type: Sets the default queue type for tasks (default: classic)
  • worker_detect_quorum_queues: Controls automatic detection of quorum queues (default: True)

Contributed in #9207, #9121, and #9599.

For details regarding the 404 errors, see New Year's Security Incident.

Soft Shutdown Mechanism

Soft shutdown is a time limited warm shutdown, initiated just before the cold shutdown. The worker will allow worker_soft_shutdown_timeout seconds for all currently executing tasks to finish before it terminates. If the time limit is reached, the worker will initiate a cold shutdown and cancel all currently executing tasks.

This feature is particularly valuable when using brokers with visibility timeout mechanisms, such as Redis or SQS. It allows the worker enough time to re-queue tasks that were not completed before exiting, preventing task loss during worker shutdown.

See Stopping the worker for complete documentation on worker shutdown types.

Configuration options:

  • worker_soft_shutdown_timeout: Sets the duration in seconds for the soft shutdown period (default: 0.0, disabled)
  • worker_enable_soft_shutdown_on_idle: Controls whether soft shutdown should be enabled even when the worker is idle (default: False)

Contributed by @Nusnus in #9213, #9231, and #9238.

Pydantic Support

New native support for Pydantic models in tasks. This integration allows you to leverage Pydantic's powerful data validation and serialization capabilities directly in your Celery tasks.

Example usage:

from pydantic import BaseModel
from celery import Celery

app = Celery('tasks')

class ArgModel(BaseModel):
    value: int

class ReturnModel(BaseModel):
    value: str

@app.task(pydantic=True)
def x(arg: ArgModel) -> ReturnModel:
    # args/kwargs type hinted as Pydantic model will be converted
    assert isinstance(arg, ArgModel)

    # The returned model will be converted to a dict automatically
    return ReturnModel(value=f"example: {arg.value}")

See Argument validation with Pydantic for complete documentation.

Configuration options:

  • pydantic=True: Enables Pydantic integration for the task
  • pydantic_strict=True/False: Controls whether strict validation is enabled (default: False)
  • pydantic_context={...}: Provides additional context for validation
  • pydantic_dump_kwargs={...}: Customizes serialization behavior

Contributed by @mathiasertl in #9023, #9319, and #9393.

Google Pub/Sub Transport

New support for Google Cloud Pub/Sub as a message transport, expanding Celery's cloud integration options.

See Google Pub/Sub Transport for complete documentation.

For the Google Pub/Sub support you have to install additional dependencies:

$ pip install "celery[gcpubsub]"

Then configure your Celery application to use the Google Pub/Sub transport:

broker_url = 'gcpubsub://projects/project-id'

Contributed by @haimjether in #9351.

Python 3.13 Support

Official support for Python 3.13. All core dependencies have been updated to ensure compatibility, including Kombu and py-amqp.

This release maintains compatibility with Python 3.8 through 3.13, as well as PyPy 3.10+.

Contributed by @Nusnus in #9309 and #9350.

REMAP_SIGTERM Support

The "REMAP_SIGTERM" feature, previously undocumented, has been tested, documented, and is now officially supported. This feature allows you to remap the SIGTERM signal to SIGQUIT, enabling you to initiate a soft or cold shutdown using TERM instead of QUIT.

This is particularly useful in containerized environments where SIGTERM is the standard signal for graceful termination.

See Cold Shutdown documentation for more info.

To enable this feature, set the environment variable:

export REMAP_SIGTERM="SIGQUIT"

Contributed by @Nusnus in #9461.

Database Backend Improvements

New create_tables_at_setup option for the database backend. This option controls when database tables are created, allowing for non-lazy table creation.

By default (create_tables_at_setup=True), tables are created during backend initialization. Setting this to False defers table creation until they are actually needed, which can be useful in certain deployment scenarios where you want more control over database schema management.

See Database backend settings for complete documentation.

Configuration:

app.conf.result_backend = 'db+sqlite:///results.db'
app.conf.database_create_tables_at_setup = False

Contributed by @MarcBresson in #9228.

What's Changed

  • (docs): use correct version celery v.5.4.x by @FraCata00 in #8975
  • Update mypy to 1.10.0 by @pyup-bot in #8977
  • Limit pymongo<4.7 when Python <= 3.10 due to breaking changes in 4.7 by @Nusnus in #8988
  • Bump pytest from 8.1.1 to 8.2.0 by @dependabot in #8987
  • Update README to Include FastAPI in Framework Integration Section by @pedroimpulcetto in #8978
  • Clarify return values of ..._on_commit methods by @browniebroke in #8984
  • add kafka broker docs by @thuibr in #8935
  • Limit pymongo<4.7 regardless of Python version by @Nusnus in #8999
  • Update pymongo[srv] requirement from <4.7,>=4.0.2 to >=4.0.2,<4.8 by @dependabot in #9000
  • Update elasticsearch requirement from <=8.13.0 to <=8.13.1 by @dependabot in #9004
  • security: SecureSerializer: support generic low-level serializers by @shirsa in #8982
  • don't kill if pid same as file (#8997) by @lewijw in #8998
  • Update cryptography to 42.0.6 by @pyup-bot in #9005
  • Bump cryptography from 42.0.6 to 42.0.7 by @dependabot in #9009
  • don't kill if pid same as file (#8997) (#8998) by @lewijw in #9007
  • Added -vv to unit, integration and smoke tests by @Nusnus in #9014
  • SecuritySerializer: ensure pack separator will not be conflicted with serialized fields by @shirsa in #9010
  • Update sphinx-click to 5.2.2 by @pyup-bot in #9025
  • Bump sphinx-click from 5.2.2 to 6.0.0 by @dependabot in #9029
  • Fix a typo to display the help message in first-steps-with-django by @ppawlak in #9036
  • Pinned requests to v2.31.0 due to docker-py bug #3256 by @Nusnus in #9039
  • Fix certificate validity check by @SPKorhonen in #9037
  • Revert "Pinned requests to v2.31.0 due to docker-py bug #3256" by @Nusnus in #9043
  • Bump pytest from 8.2.0 to 8.2.1 by @dependabot in #9035
  • Update elasticsearch requirement from <=8.13.1 to <=8.13.2 by @dependabot in #9045
  • Fix detection of custom task set as class attribute with Django by @browniebroke in #9038
  • Update elastic-transport requirement from <=8.13.0 to <=8.13.1 by @dependabot in #9050
  • Bump pycouchdb from 1.14.2 to 1.16.0 by @dependabot in #9052
  • Update pytest to 8.2.2 by @pyup-bot in #9060
  • Bump cryptography from 42.0.7 to 42.0.8 by @dependabot in #9061
  • Update elasticsearch requirement from <=8.13.2 to <=8.14.0 by @dependabot in #9069
  • [enhance feature] Crontab schedule: allow using month names by @farahats9 in #9068
  • Enhance tox environment: [testenv:clean] by @Nusnus in #9072
  • Clarify docs about Reserve one task at a time by @quique0194 in #9073
  • GCS docs fixes by @benglewis in #9075
  • Use hub.remove_writer instead of hub.remove for write fds (#4185) by @IdanHaim in #9055
  • Class method to process crontab string by @jayeff in #9079
  • Fixed smoke tests env bug when using integration tasks that rely on Redis by @Nusnus in #9090
  • Bugfix - a task will run multiple times when chaining chains with groups by @DorSSS in #9021
  • Bump mypy from 1.10.0 to 1.10.1 by @dependabot in #9096
  • Don't add a separator to global_keyprefix if it already has one by @naktinis in #9080
  • Update pymongo[srv] requirement from <4.8,>=4.0.2 to >=4.0.2,<4.9 by @dependabot in #9111
  • Added missing import in examples for Django by @giovanniacg in #9099
  • Bump Kombu to v5.4.0rc1 by @Nusnus in #9117
  • Removed skipping Redis in t/smoke/tests/test_consumer.py tests by @Nusnus in #9118
  • Update pytest-subtests to 0.13.0 by @pyup-bot in #9120
  • Increased smoke tests CI timeout by @Nusnus in #9122
  • Bump Kombu to v5.4.0rc2 by @Nusnus in #9127
  • Update zstandard to 0.23.0 by @pyup-bot in #9129
  • Update pytest-subtests to 0.13.1 by @pyup-bot in #9130
  • Changed retry to tenacity in smoke tests by @Nusnus in #9133
  • Bump mypy from 1.10.1 to 1.11.0 by @dependabot in #9135
  • Update cryptography to 43.0.0 by @pyup-bot in #9138
  • Update pytest to 8.3.1 by @pyup-bot in #9137
  • Added support for Quorum Queues by @Nusnus in #9121
  • Bump Kombu to v5.4.0rc3 by @Nusnus in #9139
  • Cleanup in Changelog.rst by @Nusnus in #9141
  • Update Django docs for CELERY_CACHE_BACKEND by @tylerlwsmith in #9143
  • Added missing docs to previous releases by @Nusnus in #9144
  • Fixed a few documentation build warnings by @Nusnus in #9145
  • docs(README): link invalid by @MerleLiuKun in #9148
  • Prepare for (pre) release: v5.5.0b1 by @Nusnus in #9146
  • Bump pytest from 8.3.1 to 8.3.2 by @dependabot in #9153
  • Remove setuptools deprecated test command from setup.py by @sevdog in #9159
  • Pin pre-commit to latest version 3.8.0 from Python 3.9 by @pyup-bot in #9156
  • Bump mypy from 1.11.0 to 1.11.1 by @dependabot in #9164
  • Change "docker-compose" to "docker compose" in Makefile by @Nusnus in #9169
  • update python versions and docker compose by @mathiasertl in #9171
  • Add support for Pydantic model validation/serialization (fixes #8751) by @mathiasertl in #9023
  • Allow local dynamodb to be installed on another host than localhost by @peerjakobsen in #8965
  • Terminate job implementation for gevent concurrency backend by @ldsink in #9083
  • Bump Kombu to v5.4.0 by @Nusnus in #9177
  • Add check for soft_time_limit and time_limit values by @ashm-dev in #9173
  • Prepare for (pre) release: v5.5.0b2 by @Nusnus in #9178
  • Added SQS (localstack) broker to canvas smoke tests by @Nusnus in #9179
  • Pin elastic-transport to <= latest version 8.15.0 by @pyup-bot in #9182
  • Update elasticsearch requirement from <=8.14.0 to <=8.15.0 by @dependabot in #9186
  • improve formatting by @Bonifacio2 in #9188
  • Add basic helm chart for celery by @necromancerthedark in #9181
  • Update kafka.rst by @lokot0k in #9194
  • Update pytest-order to 1.3.0 by @pyup-bot in #9198
  • Update mypy to 1.11.2 by @pyup-bot in #9206
  • all added to routes by @dhruvji in #9204
  • Fix typos discovered by codespell by @cclauss in #9212
  • Use tzdata extras with zoneinfo backports by @auvipy in #8286
  • Use docker compose in Contributing's doc build section by @KeisukeYamashita in #9219
  • Failing test for issue #9119 by @mgedmin in #9215
  • Fix date_done timezone issue by @FKgk in #8385
  • CI Fixes to smoke tests by @Nusnus in #9223
  • fix: passes current request context when pushing to request_stack by @nikatlas in #9208
  • Fix broken link in the Using RabbitMQ docs page by @thedrow in #9226
  • Added Soft Shutdown Mechanism by @Nusnus in #9213
  • Added worker_enable_soft_shutdown_on_idle by @Nusnus in #9231
  • Bump cryptography from 43.0.0 to 43.0.1 by @dependabot in #9233
  • Added docs regarding the relevancy of soft shutdown and ETA tasks by @Nusnus in #9238
  • Show broker_connection_retry_on_startup warning only if it evaluates as False by @serl in #9227
  • Fixed docker-docs CI failure by @Nusnus in #9240
  • Added docker cleanup auto-fixture to improve smoke tests stability by @Nusnus in #9243
  • print is not thread-safe, so should not be used in signal handler by @Zhong-z in #9222
  • Prepare for (pre) release: v5.5.0b3 by @Nusnus in #9244
  • Correct the error description in exception message when validate soft_time_limit by @narasux in #9246
  • Update msgpack to 1.1.0 by @pyup-bot in #9249
  • chore(utils/time.py): rename _is_ambigious -> _is_ambiguous by @pachewise in #9248
  • Reduced Smoke Tests to min/max supported python (3.8/3.12) by @Nusnus in #9252
  • Update pytest to 8.3.3 by @pyup-bot in #9253
  • Update elasticsearch requirement from <=8.15.0 to <=8.15.1 by @dependabot in #9255
  • update mongodb without deprecated [srv] extra requirement by @fmigneault in #9258
  • blacksmith.sh: Migrate workflows to Blacksmith by @blacksmith-sh in #9261
  • Fixes #9119: inject dispatch_uid for retry-wrapped receivers by @pachewise in #9247
  • Run all smoke tests CI jobs together by @Nusnus in #9263
  • Improve documentation on visibility timeout by @kylez-ithaka in #9264
  • Bump pytest-celery to 1.1.2 by @Nusnus in #9267
  • Added missing "app.conf.visibility_timeout" in smoke tests by @Nusnus in #9266
  • Improved stability with t/smoke/tests/test_consumer.py by @Nusnus in #9268
  • Improved Redis container stability in the smoke tests by @Nusnus in #9271
  • Disabled EXHAUST_MEMORY tests in Smoke-tasks by @Nusnus in #9272
  • Marked xfail for test_reducing_prefetch_count with Redis - flaky test by @Nusnus in #9273
  • Fixed pypy unit tests random failures in the CI by @Nusnus in #9275
  • Fixed more pypy unit tests random failures in the CI by @Nusnus in #9278
  • Fix Redis container from aborting randomly by @Nusnus in #9276
  • Run Integration & Smoke CI tests together after unit tests passes by @Nusnus in #9280
  • Added "loglevel verbose" to Redis containers in smoke tests by @Nusnus in #9282
  • Fixed Redis error in the smoke tests: "Possible SECURITY ATTACK detected" by @Nusnus in #9284
  • Refactored the smoke tests github workflow by @Nusnus in #9285
  • Increased --reruns 3->4 in smoke tests by @Nusnus in #9286
  • Improve stability of smoke tests (CI and Local) by @Nusnus in #9287
  • Fixed Smoke tests CI "test-case" lables (specific instead of general) by @Nusnus in #9288
  • Use assert_log_exists instead of wait_for_log in worker smoke tests by @Nusnus in #9290
  • Optimized t/smoke/tests/test_worker.py by @Nusnus in #9291
  • Enable smoke tests dockers check before each test starts by @Nusnus in #9292
  • Relaxed smoke tests flaky tests mechanism by @Nusnus in #9293
  • Updated quorum queue detection to handle multiple broker instances by @bkienker in #9294
  • Non-lazy table creation for database backend by @MarcBresson in #9228
  • Pin pymongo to latest version 4.9 by @pyup-bot in #9297
  • Bump pymongo from 4.9 to 4.9.1 by @dependabot in #9298
  • Bump Kombu to v5.4.2 by @Nusnus in #9304
  • Use rabbitmq:3 in stamping smoke tests by @Nusnus in #9307
  • Bump pytest-celery to 1.1.3 by @Nusnus in #9308
  • Added Python 3.13 Support by @Nusnus in #9309
  • Add log when global qos is disabled by @thedrow in #9296
  • Added official release docs (whatsnew) for v5.5 by @Nusnus in #9312
  • Enable Codespell autofix by @Nusnus in #9313
  • Pydantic typehints: Fix optional, allow generics by @mathiasertl in #9319
  • Prepare for (pre) release: v5.5.0b4 by @Nusnus in #9322
  • Added Blacksmith.sh to the Sponsors section in the README by @Nusnus in #9323
  • Revert "Added Blacksmith.sh to the Sponsors section in the README" by @Nusnus in #9324
  • Added Blacksmith.sh to the Sponsors section in the README by @Nusnus in #9325
  • Added missing " |oc-sponsor-3|” in README by @Nusnus in #9326
  • Use Blacksmith SVG logo by @Nusnus in #9327
  • Updated Blacksmith SVG logo by @Nusnus in #9328
  • Revert "Updated Blacksmith SVG logo" by @Nusnus in #9329
  • Update pymongo to 4.10.0 by @pyup-bot in #9330
  • Update pymongo to 4.10.1 by @pyup-bot in #9332
  • Update user guide to recommend delay_on_commit by @browniebroke in #9333
  • Pin pre-commit to latest version 4.0.0 (Python 3.9+) by @pyup-bot in #9334
  • Update ephem to 4.1.6 by @pyup-bot in #9336
  • Updated Blacksmith SVG logo by @Nusnus in #9337
  • Prepare for (pre) release: v5.5.0rc1 by @Nusnus in #9341
  • Fix: Treat dbm.error as a corrupted schedule file by @stumpylog in #9331
  • Pin pre-commit to latest version 4.0.1 by @pyup-bot in #9343
  • Added Python 3.13 to Dockerfiles by @Nusnus in #9350
  • Skip test_pool_restart_import_modules on PyPy due to test issue by @Nusnus in #9352
  • Update elastic-transport requirement from <=8.15.0 to <=8.15.1 by @dependabot in #9347
  • added dragonfly logo by @auvipy in #9353
  • Update README.rst by @auvipy in #9354
  • Update README.rst by @auvipy in #9355
  • Update mypy to 1.12.0 by @pyup-bot in #9356
  • Bump Kombu to v5.5.0rc1 by @Nusnus in #9357
  • Fix celery --loader option parsing by @0x2b3bfa0 in #9361
  • Add support for Google Pub/Sub transport by @haimjether in #9351
  • Add native incr support for GCSBackend by @haimjether in #9302
  • fix(perform_pending_operations): prevent task duplication on shutdown… by @moaddib666 in #9348
  • Update grpcio to 1.67.0 by @pyup-bot in #9365
  • Update google-cloud-firestore to 2.19.0 by @pyup-bot in #9364
  • Annotate celery/utils/timer2.py by @hmnfalahi in #9362
  • Update cryptography to 43.0.3 by @pyup-bot in #9366
  • Update mypy to 1.12.1 by @pyup-bot in #9368
  • Bump mypy from 1.12.1 to 1.13.0 by @dependabot in #9373
  • Pass timeout and confirm_timeout to producer.publish() by @thedrow in #9374
  • Bump Kombu to v5.5.0rc2 by @Nusnus in #9382
  • Bump pytest-cov from 5.0.0 to 6.0.0 by @dependabot in #9388
  • default strict to False for pydantic tasks by @mathiasertl in #9393
  • Only log that global QoS is disabled if using amqp by @thedrow in #9395
  • chore: update sponsorship logo by @Niennienzz in #9398
  • Allow custom hostname for celery_worker in celery.contrib.pytest / celery.contrib.testing.worker by @SlowMo24 in #9405
  • Removed docker-docs from CI (optional job, malfunctioning) by @Nusnus in #9406
  • Added a utility to format changelogs from the auto-generated GitHub release notes by @Nusnus in #9408
  • Bump codecov/codecov-action from 4 to 5 by @dependabot in #9412
  • Update elasticsearch requirement from <=8.15.1 to <=8.16.0 by @dependabot in #9410
  • Native Delayed Delivery in RabbitMQ by @thedrow in #9207
  • Prepare for (pre) release: v5.5.0rc2 by @Nusnus in #9416
  • Document usage of broker_native_delayed_delivery_queue_type by @thedrow in #9419
  • Adjust section in what's new document regarding quorum queues support by @thedrow in #9420
  • Update pytest-rerunfailures to 15.0 by @pyup-bot in #9422
  • Document group unrolling by @thedrow in #9421
  • fix small typo acces -> access by @sharuzzaman in #9434
  • Update cryptography to 44.0.0 by @pyup-bot in #9437
  • Added pypy to Dockerfile by @Nusnus in #9438
  • Skipped flaky tests on pypy (all pass after ~10 reruns) by @Nusnus in #9439
  • Allowing managed credentials for azureblockblob by @PieterBlomme in #9430
  • Allow passing Celery objects to the Click entry point by @0x2b3bfa0 in #9426
  • support Request termination for gevent by @woutdenolf in #9440
  • Prevent event_mask from being overwritten. by @Androidown in #9432
  • Update pytest to 8.3.4 by @pyup-bot in #9444
  • Prepare for (pre) release: v5.5.0rc3 by @Nusnus in #9450
  • Bugfix: SIGQUIT not initiating cold shutdown when task_acks_late=False by @Nusnus in #9461
  • Fixed pycurl dep with Python 3.8 by @Nusnus in #9471
  • Update elasticsearch requirement from <=8.16.0 to <=8.17.0 by @dependabot in #9469
  • Bump pytest-subtests from 0.13.1 to 0.14.1 by @dependabot in #9459
  • documentation: Added a type annotation to the periodic task example by @Avamander in #9473
  • Prepare for (pre) release: v5.5.0rc4 by @Nusnus in #9474
  • Bump mypy from 1.13.0 to 1.14.0 by @dependabot in #9476
  • Fix cassandra backend port settings not working by @kairi003 in #9465
  • Unroll group when a group with a single item is chained using the | operator by @thedrow in #9456
  • fix(django): catch the right error when trying to close db connection by @Lotram in #9392
  • Replacing a task with a chain which contains a group now returns a result instead of hanging by @thedrow in #9484
  • Avoid using a group of one as it is now unrolled into a chain by @thedrow in #9510
  • Link to the correct IRC network by @yigitsever in #9509
  • Bump pytest-github-actions-annotate-failures from 0.2.0 to 0.3.0 by @dependabot in #9504
  • Update canvas.rst to fix output result from chain object by @kamalfarahani in #9502
  • Unauthorized Changes Cleanup by @Nusnus in #9528
  • [RE-APPROVED] fix(django): catch the right error when trying to close db connection by @Nusnus in #9529
  • [RE-APPROVED] Link to the correct IRC network by @Nusnus in #9531
  • [RE-APPROVED] Update canvas.rst to fix output result from chain object by @Nusnus in #9532
  • Update test-ci-base.txt by @auvipy in #9539
  • Update install-pyenv.sh by @auvipy in #9540
  • Update elasticsearch requirement from <=8.17.0 to <=8.17.1 by @dependabot in #9518
  • Bump google-cloud-firestore from 2.19.0 to 2.20.0 by @dependabot in #9493
  • Bump mypy from 1.14.0 to 1.14.1 by @dependabot in #9483
  • Update elastic-transport requirement from <=8.15.1 to <=8.17.0 by @dependabot in #9490
  • Revert "[pre-commit.ci] pre-commit autoupdate" by @Nusnus in #9545
  • Update Dockerfile by adding missing Python version 3.13 by @auvipy in #9549
  • Fix typo for default of sig by @daveisfera in #9495
  • fix(crontab): resolve constructor type conflicts by @pcrock-thmdo in #9551
  • worker_max_memory_per_child: kilobyte is 1024 bytes by @mksm in #9553
  • Fix formatting in quorum queue docs by @HenrikOssipoff in #9555
  • Bump cryptography from 44.0.0 to 44.0.1 by @dependabot in #9556
  • Fix the send_task method when detecting if the native delayed delivery approach is available by @mikhaillazko in #9552
  • Reverted PR #7814 & minor code improvement by @MehrazRumman in #9494
  • Improved donation and sponsorship visibility by @Nusnus in #9558
  • Updated the Getting Help section, replacing deprecated with new resources by @Nusnus in #9559
  • Fixed django example by @Nusnus in #9562
  • Bump Kombu to v5.5.0rc3 by @Nusnus in #9564
  • Bump ephem from 4.1.6 to 4.2 by @dependabot in #9565
  • Bump pytest-celery to v1.2.0 by @Nusnus in #9568
  • Remove dependency on pycurl by @jmsmkn in #9526
  • Set TestWorkController.test by @WilliamDEdwards in #9574
  • Fixed bug when revoking by stamped headers a stamp that does not exist by @Nusnus in #9575
  • Canvas Stamping Doc Fixes by @Nusnus in #9578
  • Bugfix: Chord with a chord in header doesn't invoke error callback on inner chord header failure (default config) by @Nusnus in #9580
  • Prepare for (pre) release: v5.5.0rc5 by @Nusnus in #9582
  • Bump google-cloud-firestore from 2.20.0 to 2.20.1 by @dependabot in #9584
  • Fix tests with Click 8.2 by @cjwatson in #9590
  • Bump cryptography from 44.0.1 to 44.0.2 by @dependabot in #9591
  • Update elasticsearch requirement from <=8.17.1 to <=8.17.2 by @dependabot in #9594
  • Bump pytest from 8.3.4 to 8.3.5 by @dependabot in #9598
  • Refactored and Enhanced DelayedDelivery bootstep by @Nusnus in #9599
  • Improve docs about acks_on_failure_or_timeout by @ya-pekatoros in #9577
  • Update SECURITY.md by @Nusnus in #9609
  • remove flake8plus as not needed anymore by @auvipy in #9610
  • remove [bdist_wheel] universal = 0 from setup.cfg as not needed by @auvipy in #9611
  • remove importlib-metadata as not needed in python3.8 anymore by @auvipy in #9612
  • feat: define exception_safe_to_retry for redisbackend by @drienkop in #9614
  • Bump Kombu to v5.5.0 by @Nusnus in #9615
  • Update elastic-transport requirement from <=8.17.0 to <=8.17.1 by @dependabot in #9616
  • [docs] fix first-steps by @isidroas in #9618
  • Revert "Improve docs about acks_on_failure_or_timeout" by @auvipy in #9606
  • Improve CI stability and performance by @Nusnus in #9624
  • Improved explanation for Database transactions at user guide for tasks by @Soham7777777 in #9617
  • update tests to use python 3.8 codes only by @auvipy in #9627
  • #9597: Ensure surpassing Hard Timeout limit when task_acks_on_failure_or_timeout is False rejects the task by @JacksonKontny in #9626
  • Lock Kombu to v5.5.x (using urllib3 instead of pycurl) by @Nusnus in #9632
  • Lock pytest-celery to v1.2.x (using urllib3 instead of pycurl) by @Nusnus in #9633
  • Add Codecov Test Analytics by @JerrySentry in #9635
  • Bump Kombu to v5.5.2 by @Nusnus in #9643
  • Prepare for release: v5.5.0 by @Nusnus in #9644

New Contributors

Full Changelog: v5.4.0...v5.5.0

Don't miss a new celery release

NewReleases is sending notifications on new releases.