RedBeat
=======
.. image:: https://img.shields.io/pypi/pyversions/celery-redbeat.svg
:target: https://pypi.python.org/pypi/celery-redbeat
:alt: Python Versions
.. image:: https://img.shields.io/pypi/v/celery-redbeat.svg
:target: https://pypi.python.org/pypi/celery-redbeat
:alt: PyPI Package
.. image:: https://github.com/sibson/redbeat/workflows/RedBeat%20CI/badge.svg
:target: https://github.com/sibson/redbeat/actions
:alt: Actions Status
.. image:: https://readthedocs.org/projects/redbeat/badge/?version=latest&style=flat
:target: https://redbeat.readthedocs.io/en/latest/
:alt: ReadTheDocs
.. image:: https://img.shields.io/badge/code%20style-black-000000.svg
:target: https://github.com/psf/black
:alt: Code style: black
`RedBeat <https://github.com/sibson/redbeat>`_ is a
`Celery Beat Scheduler <http://celery.readthedocs.org/en/latest/userguide/periodic-tasks.html>`_
that stores the scheduled tasks and runtime metadata in `Redis <http://redis.io/>`_.
Why RedBeat?
-------------
#. Dynamic live task creation and modification, without lengthy downtime
#. Externally manage tasks from any language with Redis bindings
#. Shared data store; Beat isn't tied to a single drive or machine
#. Fast startup even with a large task count
#. Prevent accidentally running multiple Beat servers
For more background on the genesis of RedBeat see this `blog post <https://blog.heroku.com/redbeat-celery-beat-scheduler>`_
Getting Started
---------------
Install with pip:
.. code-block:: console
pip install celery-redbeat
Configure RedBeat settings in your Celery configuration file:
.. code-block:: python
redbeat_redis_url = "redis://localhost:6379/1"
Then specify the scheduler when running Celery Beat:
.. code-block:: console
celery beat -S redbeat.RedBeatScheduler
RedBeat uses a distributed lock to prevent multiple instances running.
To disable this feature, set:
.. code-block:: python
redbeat_lock_key = None
More details available on `Read the Docs <https://redbeat.readthedocs.io/en/latest/>`_
Development
--------------
RedBeat is available on `GitHub <https://github.com/sibson/redbeat>`_
Once you have the source you can run the tests with the following commands::
pip install -r requirements-dev.txt
python -m unittest discover tests
You can also quickly fire up a sample Beat instance with::
celery beat --config exampleconf
Raw data
{
"_id": null,
"home_page": "https://github.com/sibson/redbeat",
"name": "celery-redbeat",
"maintainer": "",
"docs_url": null,
"requires_python": "",
"maintainer_email": "",
"keywords": "python,celery,beat,redis",
"author": "Marc Sibson",
"author_email": "sibson+redbeat@gmail.com",
"download_url": "https://files.pythonhosted.org/packages/35/0d/63cf4db35c111554913199a54f32be3495526ff08189f9d79a879abcc6ad/celery-redbeat-2.2.0.tar.gz",
"platform": null,
"description": "RedBeat\n=======\n\n.. image:: https://img.shields.io/pypi/pyversions/celery-redbeat.svg\n :target: https://pypi.python.org/pypi/celery-redbeat\n :alt: Python Versions\n\n.. image:: https://img.shields.io/pypi/v/celery-redbeat.svg\n :target: https://pypi.python.org/pypi/celery-redbeat\n :alt: PyPI Package\n\n.. image:: https://github.com/sibson/redbeat/workflows/RedBeat%20CI/badge.svg\n :target: https://github.com/sibson/redbeat/actions\n :alt: Actions Status\n\n.. image:: https://readthedocs.org/projects/redbeat/badge/?version=latest&style=flat\n :target: https://redbeat.readthedocs.io/en/latest/\n :alt: ReadTheDocs\n\n.. image:: https://img.shields.io/badge/code%20style-black-000000.svg\n :target: https://github.com/psf/black\n :alt: Code style: black\n\n`RedBeat <https://github.com/sibson/redbeat>`_ is a\n`Celery Beat Scheduler <http://celery.readthedocs.org/en/latest/userguide/periodic-tasks.html>`_\nthat stores the scheduled tasks and runtime metadata in `Redis <http://redis.io/>`_.\n\nWhy RedBeat?\n-------------\n\n#. Dynamic live task creation and modification, without lengthy downtime\n#. Externally manage tasks from any language with Redis bindings\n#. Shared data store; Beat isn't tied to a single drive or machine\n#. Fast startup even with a large task count\n#. Prevent accidentally running multiple Beat servers\n\nFor more background on the genesis of RedBeat see this `blog post <https://blog.heroku.com/redbeat-celery-beat-scheduler>`_\n\nGetting Started\n---------------\n\nInstall with pip:\n\n.. code-block:: console\n\n pip install celery-redbeat\n\nConfigure RedBeat settings in your Celery configuration file:\n\n.. code-block:: python\n\n redbeat_redis_url = \"redis://localhost:6379/1\"\n\nThen specify the scheduler when running Celery Beat:\n\n.. code-block:: console\n\n celery beat -S redbeat.RedBeatScheduler\n\nRedBeat uses a distributed lock to prevent multiple instances running.\nTo disable this feature, set:\n\n.. code-block:: python\n\n redbeat_lock_key = None\n\nMore details available on `Read the Docs <https://redbeat.readthedocs.io/en/latest/>`_\n\nDevelopment\n--------------\nRedBeat is available on `GitHub <https://github.com/sibson/redbeat>`_\n\nOnce you have the source you can run the tests with the following commands::\n\n pip install -r requirements-dev.txt\n python -m unittest discover tests\n\nYou can also quickly fire up a sample Beat instance with::\n\n celery beat --config exampleconf\n",
"bugtrack_url": null,
"license": "Apache License, Version 2.0",
"summary": "A Celery Beat Scheduler using Redis for persistent storage",
"version": "2.2.0",
"project_urls": {
"Homepage": "https://github.com/sibson/redbeat"
},
"split_keywords": [
"python",
"celery",
"beat",
"redis"
],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "350d63cf4db35c111554913199a54f32be3495526ff08189f9d79a879abcc6ad",
"md5": "b3fb33638162ce8b97ba701dd33acb5e",
"sha256": "71104729380d4eaefd91a9b7d270ba7851bfff9ad55a43ac8365acbb0c608b77"
},
"downloads": -1,
"filename": "celery-redbeat-2.2.0.tar.gz",
"has_sig": false,
"md5_digest": "b3fb33638162ce8b97ba701dd33acb5e",
"packagetype": "sdist",
"python_version": "source",
"requires_python": null,
"size": 21372,
"upload_time": "2023-12-22T13:34:29",
"upload_time_iso_8601": "2023-12-22T13:34:29.853005Z",
"url": "https://files.pythonhosted.org/packages/35/0d/63cf4db35c111554913199a54f32be3495526ff08189f9d79a879abcc6ad/celery-redbeat-2.2.0.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2023-12-22 13:34:29",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "sibson",
"github_project": "redbeat",
"travis_ci": false,
"coveralls": false,
"github_actions": true,
"lcname": "celery-redbeat"
}