aplr/kafkaesk

Laravel Kafka queue driver

v1.0.3 2020-05-15 16:52 UTC

This package is auto-updated.

Last update: 2024-04-05 09:33:59 UTC


README

Kafkaesk adds support for Apache Kafka to Laravel Queues. It builds upon the rdkafka php extension, which you will have to install seperately. Also, you have to install the C/C++ client library librdkafka upfront. Afterwards, you can freely push jobs to your favorite Kafka queue!

Kafkaesk supports PHP 7.2-7.4 and requires Laravel 6-7. If you still need to support Laravel 5 use rapideinternet/laravel-queue-kafka, which Kafkaesk is a fork of.

Packagist Version GitHub Workflow Status PHP from Packagist GitHub license

Installation

To install the latest version of aplr/kafkaesk just require it using composer.

composer require aplr/kafkaesk

This package is using Laravel's package auto-discovery, so it doesn't require you to manually add the ServiceProvider. If you've opted out of this feature, add the ServiceProvider to the providers array in config/app.php:

Aplr\Kafkaesk\ServiceProvider::class,

Requirements

Make sure you have installed the C/C++ client library librdkafka. If you're running macOS, you can simply use Homebrew to install it.

brew install librdkafka

Additionally you have to install the php extension rdkafka. You can do this either manually or simply by using pecl.

pecl install rdkafka

If both installs succeed, you're all set!

Configuration

The default configuration is set in config/kafkaesk.php. Merge the contents of this file with the connections array in your local config/queue.php. You can do this using the command below.

php artisan vendor:publish --provider="Aplr\Kafkaesk\ServiceProvider"

Environment variables

When using the default configuration, you can also use the environment variables described below to configure the queue driver.

Name Default Description
KAFKA_QUEUE default The name of the default queue.
KAFKA_CONSUMER_GROUP_ID laravel The group in which the consumer resides.
KAFKA_BROKERS localhost Kafka broker address.
KAFKA_ERROR_SLEEP 5 Seconds to sleep on communication error.
KAFKA_DEADLOCK_SLEEP 2 Seconds to sleep on deadlocks
KAFKA_SASL_USERNAME SASL username
KAFKA_SASL_PASSWORD SASL password

Usage

Since Kafkaesk is just a driver for Laravel Queues, just read through their extensive documentation.

Limitations

Currently, deferring jobs on the queue using the later function of Laravel Queues is not yet supported by this library. Feel free to add support by creating a PR!

Acknowledgements

This library is a fork of the outdated rapideinternet/laravel-queue-kafka, adding support for Laravel 6-7, fixing tests and fancying everything up a bit.

Licence

Kafkaesk is licenced under The MIT Licence (MIT).