Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/joowani/kq
Kafka-based Job Queue for Python
https://github.com/joowani/kq
apache-kafka job-queue kafka kafka-client kafka-consumer kafka-producer producer-consumer python python3 queueing worker-queue
Last synced: 2 days ago
JSON representation
Kafka-based Job Queue for Python
- Host: GitHub
- URL: https://github.com/joowani/kq
- Owner: joowani
- License: mit
- Created: 2016-10-16T02:49:53.000Z (about 8 years ago)
- Default Branch: main
- Last Pushed: 2022-02-04T12:38:12.000Z (almost 3 years ago)
- Last Synced: 2024-12-24T23:04:44.911Z (9 days ago)
- Topics: apache-kafka, job-queue, kafka, kafka-client, kafka-consumer, kafka-producer, producer-consumer, python, python3, queueing, worker-queue
- Language: Python
- Homepage: http://kq.readthedocs.io
- Size: 108 KB
- Stars: 571
- Watchers: 12
- Forks: 24
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
Awesome Lists containing this project
README
# KQ: Kafka Job Queue for Python
![Build](https://github.com/joowani/kq/workflows/Build/badge.svg)
![CodeQL](https://github.com/joowani/kq/workflows/CodeQL/badge.svg)
[![codecov](https://codecov.io/gh/joowani/kq/branch/main/graph/badge.svg?token=ha9Xg7eULv)](https://codecov.io/gh/joowani/kq)
[![PyPI version](https://badge.fury.io/py/kq.svg)](https://badge.fury.io/py/kq)
[![GitHub license](https://img.shields.io/github/license/joowani/kq?color=brightgreen)](https://github.com/joowani/kq/blob/main/LICENSE)
![Python version](https://img.shields.io/badge/python-3.6%2B-blue)**KQ (Kafka Queue)** is a lightweight Python library which lets you enqueue and
execute jobs asynchronously using [Apache Kafka](https://kafka.apache.org/). It uses
[kafka-python](https://github.com/dpkp/kafka-python) under the hood.## Announcements
* Support for Python 3.5 will be dropped from KQ version 3.0.0.
* See [releases](https://github.com/joowani/kq/releases) for latest updates.## Requirements
* [Apache Kafka](https://kafka.apache.org) 0.9+
* Python 3.6+## Installation
Install using [pip](https://pip.pypa.io):
```shell
pip install kq
```## Getting Started
Start your Kafka instance.
Example using [Docker](https://github.com/lensesio/fast-data-dev):```shell
docker run -p 9092:9092 -e ADV_HOST=127.0.0.1 lensesio/fast-data-dev
```Define your KQ ``worker.py`` module:
```python
import loggingfrom kafka import KafkaConsumer
from kq import Worker# Set up logging.
formatter = logging.Formatter("[%(levelname)s] %(message)s")
stream_handler = logging.StreamHandler()
stream_handler.setFormatter(formatter)
logger = logging.getLogger("kq.worker")
logger.setLevel(logging.DEBUG)
logger.addHandler(stream_handler)# Set up a Kafka consumer.
consumer = KafkaConsumer(
bootstrap_servers="127.0.0.1:9092",
group_id="group",
auto_offset_reset="latest"
)# Set up a worker.
worker = Worker(topic="topic", consumer=consumer)
worker.start()
```Start your worker:
```shell
python my_worker.py
[INFO] Starting Worker(hosts=127.0.0.1:9092 topic=topic, group=group) ...
```Enqueue a function call:
```python
import requestsfrom kafka import KafkaProducer
from kq import Queue# Set up a Kafka producer.
producer = KafkaProducer(bootstrap_servers="127.0.0.1:9092")# Set up a queue.
queue = Queue(topic="topic", producer=producer)# Enqueue a function call.
job = queue.enqueue(requests.get, "https://google.com")# You can also specify the job timeout, Kafka message key and partition.
job = queue.using(timeout=5, key=b"foo", partition=0).enqueue(requests.get, "https://google.com")
```The worker executes the job in the background:
```shell
python my_worker.py
[INFO] Starting Worker(hosts=127.0.0.1:9092, topic=topic, group=group) ...
[INFO] Processing Message(topic=topic, partition=0, offset=0) ...
[INFO] Executing job c7bf2359: requests.api.get("https://www.google.com")
[INFO] Job c7bf2359 returned:
```See the [documentation](https://kq.readthedocs.io) for more information.