# Arroyo
<p align="center">
<!-- do not specify height so that it scales proportionally on mobile -->
<img src=docs/source/_static/arroyo-banner.png width=583 />
</p>
`Arroyo` is a library to build streaming applications that consume from and produce to Kafka.
Arroyo consists of three components:
* Consumer and producer backends
- The Kafka backend is a wrapper around the librdkafka client, and attempts to simplify rebalancing and offset management even further
- There is also an in memory and a file based consumer and producer implementation that can be used for testing
* A strategy interface
- Arroyo includes a number of pre-built strategies such as `RunTask`, `Filter`, `Reduce`, `CommitOffsets` and more.
- Users can write their own strategies, though in most cases this should not be needed as the library aims to provide generic, reusable strategies that cover most stream processing use cases
- Strategies can be chained together to form complex message processing pipelines.
* A streaming engine which manages the relationship between the consumer and strategies
- The `StreamProcessor` controls progress by the consumer and schedules work for execution by the strategies.
All documentation is in the `docs` directory. It is hosted at https://getsentry.github.io/arroyo/ and can be built locally by running `make docs`
Raw data
{
"_id": null,
"home_page": "https://github.com/getsentry/arroyo",
"name": "sentry-arroyo",
"maintainer": null,
"docs_url": null,
"requires_python": null,
"maintainer_email": null,
"keywords": null,
"author": "Sentry",
"author_email": "oss@sentry.io",
"download_url": "https://files.pythonhosted.org/packages/75/aa/05b7b32f9ae588ff9eadb2217b882d885523cf274f04c46aee60751ee174/sentry_arroyo-2.18.1.tar.gz",
"platform": null,
"description": "# Arroyo\n\n<p align=\"center\">\n <!-- do not specify height so that it scales proportionally on mobile -->\n <img src=docs/source/_static/arroyo-banner.png width=583 />\n</p>\n\n`Arroyo` is a library to build streaming applications that consume from and produce to Kafka.\n\nArroyo consists of three components:\n\n* Consumer and producer backends\n - The Kafka backend is a wrapper around the librdkafka client, and attempts to simplify rebalancing and offset management even further\n - There is also an in memory and a file based consumer and producer implementation that can be used for testing\n* A strategy interface\n - Arroyo includes a number of pre-built strategies such as `RunTask`, `Filter`, `Reduce`, `CommitOffsets` and more.\n - Users can write their own strategies, though in most cases this should not be needed as the library aims to provide generic, reusable strategies that cover most stream processing use cases\n - Strategies can be chained together to form complex message processing pipelines.\n* A streaming engine which manages the relationship between the consumer and strategies\n - The `StreamProcessor` controls progress by the consumer and schedules work for execution by the strategies.\n\nAll documentation is in the `docs` directory. It is hosted at https://getsentry.github.io/arroyo/ and can be built locally by running `make docs`\n",
"bugtrack_url": null,
"license": "Apache-2.0",
"summary": "Arroyo is a Python library for working with streaming data.",
"version": "2.18.1",
"project_urls": {
"Homepage": "https://github.com/getsentry/arroyo"
},
"split_keywords": [],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "840d1eac192cbed181116f76f62da759ad2670e6d73638428a7ce747fe5d897d",
"md5": "6e730cc1dee9a8d9840c0a607826bb61",
"sha256": "a7439c486cb29836c388d320ac9226f713882df049b83bdbefde55f0b2523cce"
},
"downloads": -1,
"filename": "sentry_arroyo-2.18.1-py3-none-any.whl",
"has_sig": false,
"md5_digest": "6e730cc1dee9a8d9840c0a607826bb61",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": null,
"size": 106363,
"upload_time": "2024-11-19T01:16:43",
"upload_time_iso_8601": "2024-11-19T01:16:43.684773Z",
"url": "https://files.pythonhosted.org/packages/84/0d/1eac192cbed181116f76f62da759ad2670e6d73638428a7ce747fe5d897d/sentry_arroyo-2.18.1-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "75aa05b7b32f9ae588ff9eadb2217b882d885523cf274f04c46aee60751ee174",
"md5": "b76f369350b014368d9fbc0360a12caf",
"sha256": "ffd335e2b6cc39ca146aff7b014816f76b6e215e20f24b1203353619cf538b52"
},
"downloads": -1,
"filename": "sentry_arroyo-2.18.1.tar.gz",
"has_sig": false,
"md5_digest": "b76f369350b014368d9fbc0360a12caf",
"packagetype": "sdist",
"python_version": "source",
"requires_python": null,
"size": 79344,
"upload_time": "2024-11-19T01:16:45",
"upload_time_iso_8601": "2024-11-19T01:16:45.585306Z",
"url": "https://files.pythonhosted.org/packages/75/aa/05b7b32f9ae588ff9eadb2217b882d885523cf274f04c46aee60751ee174/sentry_arroyo-2.18.1.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2024-11-19 01:16:45",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "getsentry",
"github_project": "arroyo",
"travis_ci": false,
"coveralls": false,
"github_actions": true,
"requirements": [],
"lcname": "sentry-arroyo"
}