Download the PHP package rapide/laravel-queue-kafka without Composer
On this page you can find all versions of the php package rapide/laravel-queue-kafka. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download rapide/laravel-queue-kafka
More information about rapide/laravel-queue-kafka
Files in rapide/laravel-queue-kafka
Package laravel-queue-kafka
Short Description Kafka driver for Laravel Queue
License MIT
Informations about the package laravel-queue-kafka
Kafka Queue driver for Laravel
Installation
-
Install librdkafka c library
-
Install the php-rdkafka PECL extension
-
a. Add the following to your php.ini file to enable the php-rdkafka extension
extension=rdkafka.so
b. Check if rdkafka is installed
Note: If you want to run this on php-fpm restart your php-fpm first.php -i | grep rdkafka
Your output should look something like this
rdkafka rdkafka support => enabled librdkafka version (runtime) => 1.0.0-RC2 librdkafka version (build) => 0.11.4.0
-
Install this package via composer using:
composer require rapide/laravel-queue-kafka
-
Add LaravelQueueKafkaServiceProvider to
providers
array inconfig/app.php
:Rapide\LaravelQueueKafka\LaravelQueueKafkaServiceProvider::class,
If you are using Lumen, put this in
bootstrap/app.php
$app->register(Rapide\LaravelQueueKafka\LumenQueueKafkaServiceProvider::class);
-
Add these properties to
.env
with proper values:QUEUE_DRIVER=kafka
-
If you want to run a worker for a specific consumer group
export KAFKA_CONSUMER_GROUP_ID="group2" && php artisan queue:work --sleep=3 --tries=3
Explaination of consumergroups can be found in this article http://blog.cloudera.com/blog/2018/05/scalability-of-kafka-messaging-using-consumer-groups/
Usage
Once you completed the configuration you can use Laravel Queue API. If you used other queue drivers you do not need to change anything else. If you do not know how to use Queue API, please refer to the official Laravel documentation: http://laravel.com/docs/queues
Testing
Run the tests with:
Acknowledgement
This library is inspired by laravel-queue-rabbitmq by vyuldashev. And the Kafka implementations by Superbalist be sure to check those out.
Contribution
You can contribute to this package by discovering bugs and opening issues. Please, add to which version of package you create pull request or issue.
Supported versions of Laravel
Tested on: [5.4, 5.5, 5.6, 5.7]
New version is underway
A version for Laravel 6,7,8 is underway. Also supporting the new RdKafka library
All versions of laravel-queue-kafka with dependencies
illuminate/database Version 5.4.*|5.5.*||5.6.*|5.7.*
illuminate/support Version 5.4.*|5.5.*|5.6.*|5.7.*
illuminate/queue Version 5.4.*|5.5.*|5.6.*|5.7.*
ext-rdkafka Version *