mgid/kafka-bundle
最新稳定版本:1.0.0
Composer 安装命令:
composer require mgid/kafka-bundle
包简介
Symfony Kafka Bundle
README 文档
README
How to use
- Install package
composer req mgid/kafka-bundle
- Create consumer. Example (src/Consumer/EmailSendConsumer.php):
<?php namespace App\Consumer; use Swift_Mailer; use Mgid\KafkaBundle\Command\Consumer; class EmailSendConsumer extends Consumer { public const QUEUE_NAME = 'email_send_queue'; /** * @var Swift_Mailer */ private $mailer; /** * @required * * @param Swift_Mailer $mailer */ public function setMailer(Swift_Mailer $mailer) { $this->mailer = $mailer; } /** * {@inheritdoc} */ protected function onMessage(array $data): void { $message = (new \Swift_Message($data['subject'])) ->setFrom($data['sender']) ->setTo($data['recipient']) ->setBody($data['body']); $this->mailer->send($message); } }
- Produce message. Example (src/Service/EmailService.php):
<?php namespace App\Service; use App\Consumer\DemoConsumer; use Mgid\KafkaBundle\DependencyInjection\Traits\ProducerTrait; class EmailService { use ProducerTrait; /** * @param array $data */ public function send(array $data): void { $this->producer->send(DemoConsumer::QUEUE_NAME, $data); } }
- Run consumer. Example:
php bin/console app:consumer:email-send
Default configuration
# config/packages/mgid_kafka.yaml mgid_kafka: producers: configuration: group.id: 'main_group' log.connection.close: 'false' metadata.broker.list: '%env(KAFKA_BROKERS)%' queue.buffering.max.messages: 100000 consumers: configuration: group.id: 'main_group' auto.offset.reset: 'smallest' log.connection.close: 'false' metadata.broker.list: '%env(KAFKA_BROKERS)%'
Read more about supported configuration properties: librdkafka configuration.
统计信息
- 总下载量: 11.04k
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 0
- 点击次数: 0
- 依赖项目数: 0
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2020-12-24