Performant pure-PHP AMQP (RabbitMQ) sync/async (ReactPHP) library
BunnyPHP requires PHP >= 5.4.0
.
Add as Composer dependency:
$ composer require bunny/bunny:@dev
You might ask if there isn't a library/extension to connect to AMQP broker (e.g. RabbitMQ) already. Yes, there are multiple options:
- ext-amqp - PHP extension
- php-amqplib - pure-PHP AMQP protocol implementation
- react-amqp - ext-amqp binding to ReactPHP
Why should you want to choose BunnyPHP instead?
-
You want nice idiomatic PHP API to work with (I'm looking at you, php-amqplib). BunnyPHP interface follows PHP's common coding standards and naming conventions. See tutorial.
-
You can't (don't want to) install PECL extension that has latest stable version in 2014. BunnyPHP isn't as such marked as stable yet. But it is already being used in production.
-
You have both classic CLI/FPM and ReactPHP applications and need to connect to RabbitMQ. BunnyPHP comes with both synchronous and asynchronous clients with same PHP-idiomatic interface. Async client uses react/promise.
Apart from that BunnyPHP is more performant than main competing library, php-amqplib. See benchmark/
directory
and php-amqplib's benchmark/
.
Benchmarks were run as:
$ php benchmark/producer.php N & php benchmark/consumer.php
Library | N (# messages) | Produce sec | Produce msg/sec | Consume sec | Consume msg/sec |
---|---|---|---|---|---|
php-amqplib | 100 | 0.0131 | 7633 | 0.0446 | 2242 |
bunnyphp | 100 | 0.0128 | 7812 | 0.0488 | 2049 |
bunnyphp +/- | +2.3% | -8.6% | |||
php-amqplib | 1000 | 0.1218 | 8210 | 0.4801 | 2082 |
bunnyphp | 1000 | 0.1042 | 9596 | 0.2919 | 3425 |
bunnyphp +/- | +17% | +64% | |||
php-amqplib | 10000 | 1.1075 | 9029 | 5.1824 | 1929 |
bunnyphp | 10000 | 0.9078 | 11015 | 2.9058 | 3441 |
bunnyphp +/- | +22% | +78% | |||
php-amqplib | 100000 | 20.7005 | 4830 | 69.0360 | 1448 |
bunnyphp | 100000 | 9.7891 | 10215 | 35.7305 | 2789 |
bunnyphp +/- | +111% | +92% |
TODO, see benchmarks/
for basic use.
-
Large part of the PHP code (almost everything in
Bunny\Protocol
namespace) is generated from spec in filespec/amqp-rabbitmq-0.9.1.json
. Look forDO NOT EDIT!
in doc comments.To change geneted files change
spec/generate.php
and run:$ php ./spec/generate.php
Works well with RabbitMQ
Does not work with ActiveMQ because it requires AMQP 1.0 which is a completely different protocol (Bunny is implementing AMQP 0.9.1)
BunnyPHP is licensed under MIT license. See LICENSE
file.