承接 kcs/messenger-extra 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

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

kcs/messenger-extra

最新稳定版本:2.5.1

Composer 安装命令:

composer require kcs/messenger-extra

包简介

Additional transports and serializer support for symfony messenger

README 文档

README

Tests

This library provides additional transports (and other things) for the symfony messenger component.

Install

composer require kcs/messenger-extra 

Transports

Doctrine DBAL

A transport using doctrine DBAL can be used through the DbalTransportFactory.

Supports delayed, prioritized, expiring (TTL) and unique messages.

The dsn supports the following schemes:

  • db2
  • mssql
  • mysql
  • mysql2
  • postgres
  • postgresql
  • pgsql
  • sqlite
  • sqlite3

Doctrine ORM

An existing ORM connection can be used with doctrine scheme.

For example doctrine://default/queue will use the default doctrine connection with the queue table.

The doctrine scheme will also register a postGenerateSchema event listener that will create the correct table during a schema update (or migration if using DoctrineMigrations)

Mongo

Transport using MongoDB PHP client as transport.

Supports delayed, prioritized, expiring (TTL) and unique messages.

Use DSN with mongodb scheme with /database/collection path (database default and queue collection are used if not specified).

Mongodb authentication

For authenticated database, with user configured per database, you could specify authSource option in DSN query string:

mongodb://user:pass@server:port/database?authSource=database 

⚠️ NOTE that if a username is passed in DSN the authSource connection option is already added to the mongo uri when passing to the client library. Its value is equal to the database selected (default if missing).

ℹ️ For information about the supported options in mongo DSN you can check the official documentation page on PHP.net

Null

Useful for testing environments, where no message should be dispatched.

Messages utilities

DelayedMessageInterface

Allows to specify a message delay. Implement this in your message class to delay the delivery of your message.

TTLAwareMessageInterface

Allows the expiration of a message. Implement this interface if you want your message to expire after a given amount of time.

UniqueMessageInterface

Adds a message only once in the queue. If another message with the same uniqueness key is present, the message is discarded.

Compatibility

Version Compatible Symfony Version Build Status
>= 2.2.0 ^4.4, ^5.0 Tests
2.0, 2.1 ^4.3, ^5.0 Not available
1.x 4.2.* Not available

Symfony bundle

A symfony bundle is included in the code under /lib: Use MessengerExtraBundle to fully integrate this library into your symfony application. Just add this to bundles.php:

 Kcs\MessengerExtra\MessengerExtraBundle::class => ['all' => true], 

Available transports and functionalities will be registered automatically.

Amazing things will come shortly.

License & Contribute

This library is released under MIT license.

Feel free to open an issue or a PR on GitHub. If you want to contribute to this project, you're welcome!

A.

统计信息

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

GitHub 信息

  • Stars: 21
  • Watchers: 3
  • Forks: 10
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2026-01-04