PHPackages                             d1oxyde/kafka-bundle - PHPackages - PHPackages  [Skip to content](#main-content)[PHPackages](/)[Directory](/)[Categories](/categories)[Trending](/trending)[Leaderboard](/leaderboard)[Changelog](/changelog)[Analyze](/analyze)[Collections](/collections)[Log in](/login)[Sign up](/register)

1. [Directory](/)
2. /
3. [Framework](/categories/framework)
4. /
5. d1oxyde/kafka-bundle

ActiveSymfony-bundle[Framework](/categories/framework)

d1oxyde/kafka-bundle
====================

Kafka Bundle for Symfony Framework

1.2.0(5y ago)011MITPHPPHP ^7.1

Since Jan 18Pushed 4y ago1 watchersCompare

[ Source](https://github.com/d1oxyde/kafka-bundle)[ Packagist](https://packagist.org/packages/d1oxyde/kafka-bundle)[ RSS](/packages/d1oxyde-kafka-bundle/feed)WikiDiscussions master Synced 1mo ago

READMEChangelog (1)Dependencies (1)Versions (2)Used By (0)

Symfony Kafka-bundle
====================

[](#symfony-kafka-bundle)

Установка
---------

[](#установка)

#### Создать файл конфигурации в вашем приложении

[](#создать-файл-конфигурации-в-вашем-приложении)

```
# config/packages/kafka.yaml
kafka:
  __client_name__:
    ## configuration: Acme\Configuration
    configuration:
      global:
        group.id: 'some-group'
        metadata.broker.list: 'kafka:9092'
        enable.auto.commit: 'true'
      topic:
        auto.offset.reset: latest
    serializer: Enqueue\RdKafka\JsonSerializer
    logger: Acme\Logger
```

Где `__client_name__` — имя вашего клиента, измение его на любой другой. Оно испольется для указания подключения при подписки на топик кафки, при вызове команды `./bin/console kafka:consume`.

В поле `configuration` описывается конфигурация для соединения с кафкой. Подробнее об конфигурации можно узнать тут -&gt; . Также, вместо параметров, можно передать класс, который должен имплементировать интерфейс `D1oxyde\KafkaBundle\Configuration`. Он полезен в том случае, если, например, необходимо динамичски вычислять значения или получать данные подключения из внешних систем.

В `serializer` передаётся класс, который десериализирует пришедшее сообщение из топика, и сериализует при отправке в топик. Он должен имплементировать интерфейс `Enqueue\RdKafka\Serializer`.

В `logger` передаётся класс, который должен имплементировать интерфейс `D1oxyde\KafkaBundle\Logger`. Он логгирует ошибки и успешную доставку сообщения.

#### Подключить бандл к проекту (`config/bundles.php`):

[](#подключить-бандл-к-проекту-configbundlesphp)

```
