small/broker-client
最新稳定版本:0.1
Composer 安装命令:
composer require small/broker-client
包简介
Implements generic message broker consumers and producers in OpenSwoole environment
README 文档
README

This library is a generic client for message brokers.
Supported messages brokers
- RabbitMq
Produce messages
Create a pool of producer to send messages :
$numProducers = 10;
$pool = new \Small\SwoolePatterns\Pool\Pool(
new \Small\BrokerClient\Manager\RabbitMqProducerManager(
$config = new \Small\BrokerClient\Config\RabbitMqConfig(
'rabbitmq.server',
'guest',
'guest',
),
$topic ='test',
), $numProducers
);
Then use pool :
$message = 'This is a test';
// Get producer
/** @var \Small\BrokerClient\Producer\RabbitMqProducer $producer */
$producer = $pool->get();
// Publish message
$producer->publish(
new Small\BrokerClient\Message\BasicEnvelop($message)
);
// Don't forget to release producer
$pool->put($producer);
Consume messages
Define a class to consume messages :
class Consumer extends \Small\BrokerClient\Consumer\AbstractRabbitMqConsumer
{
public string $test;
protected function execute(\Small\BrokerClient\Message\AbstractEnvelop $envelop): bool
{
$this->test = $envelop->getStringMessage();
return true;
}
}
And run consuming :
$munMessagesToTreat = 10;
(new Consumer())
->consume($config, $topic, 10)
;
Easier producers management with registry
// Create registry
$registry = new \Small\BrokerClient\Registry\ProducerPoolRegistry();
// Register producer
$registry->createPool(
'testProducer'
new \Small\BrokerClient\Config\RabbitMqConfig(
'rabbitmq.server',
'guest',
'guest',
), 'testTopic',
$numConnections = 20,
);
// Use producer
$producer = $registry->getPool('testProducer')->get();
$producer->publish(
new Small\BrokerClient\Message\BasicEnvelop(
'this is a test'
)
);
$registry->getPool('testProducer')->put($producer);
统计信息
- 总下载量: 0
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 0
- 点击次数: 0
- 依赖项目数: 0
- 推荐数: 0
其他信息
- 授权协议: GPL-3.0-only
- 更新时间: 2023-10-21