定制 aplr/kafkaesk 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

aplr/kafkaesk

最新稳定版本:v1.0.3

Composer 安装命令:

composer require aplr/kafkaesk

包简介

Laravel Kafka queue driver

README 文档

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).

统计信息

  • 总下载量: 2.08k
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 10
  • 点击次数: 0
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 10
  • Watchers: 1
  • Forks: 5
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2020-04-24