定制 danikdantist/queue-wrapper 二次开发

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

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

danikdantist/queue-wrapper

最新稳定版本:2.0.3

Composer 安装命令:

composer require danikdantist/queue-wrapper

包简介

kafka wrapper

README 文档

README

Install

composer require danikdantist/queue-wrapper

If you want to use Kafka, you need kafka lib https://github.com/edenhill/librdkafka and rdkafka extension for php https://github.com/arnaud-lb/php-rdkafka

You can use dockerfile to create docker image where librdkafka and PHP kafka extension already installed: https://github.com/danikdantist/Dockerfiles/blob/master/php/php5-fpm-nginx-kafka/Dockerfile

Consumer usage:

<?php

class Receiver implements DanikDantist\QueueWrapper\Interfaces\iReceivable
{
    public function receiveMessage(DanikDantist\QueueWrapper\Message $message)
    {
        echo $message->toString()."\n";
    }
}

class EchoLogger implements DanikDantist\QueueWrapper\Interfaces\iLogable
{
    public function info($info)
    {
        echo 'Info: '.$info."\n";
    }

    public function error($error)
    {
        echo 'Error: '.$error."\n";
    }
}

$config = new DanikDantist\QueueWrapper\Drivers\Kafka\Config();
$config
    ->setGroup('my_group')
    ->addBroker('172.17.0.31:9092')
    ->addTopic('my-test-topic')
    ->addTopic('my-test-topic-2')
;

$demon = new DanikDantist\QueueWrapper\Manager(new DanikDantist\QueueWrapper\Drivers\Kafka\Connector($config, new EchoLogger()));
$demon->addReceiver(new Receiver());
$demon->listenMessage();

Producer usage:

<?php

class EchoLogger implements DanikDantist\QueueWrapper\Interfaces\iLogable
{
    public function info($info)
    {
        echo 'Info: '.$info."\n";
    }

    public function error($error)
    {
        echo 'Error: '.$error."\n";
    }
}

$config = new DanikDantist\QueueWrapper\Drivers\Kafka\Config();
$config->addBroker('172.17.0.31:9092');

$demon = new DanikDantist\QueueWrapper\Manager(new DanikDantist\QueueWrapper\Drivers\Kafka\Connector($config, new EchoLogger()));

$demon->sendMessage(new DanikDantist\QueueWrapper\Message('My test message', 'my-test-topic'));

统计信息

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

GitHub 信息

  • Stars: 2
  • Watchers: 2
  • Forks: 3
  • 开发语言: PHP

其他信息

  • 授权协议: LGPL-3.0-or-later
  • 更新时间: 2016-06-04