iquety/pubsub
最新稳定版本:v2.2.1
Composer 安装命令:
composer require iquety/pubsub
包简介
Library for implementing the Publish/Subscribe architectural pattern
README 文档
README
| English | Português |
|---|
Synopsis
This repository contains the necessary functionalities to run a Publish/Subscribe system, making it possible to subscribe and publish events.
composer require iquety/pubsub
For detailed information, see Documentation Summary.
How it works
1. Run the event server
At the root of this repository, there is a terminal command to exemplify the process. It can be used as follows:
# running in local PHP ./broker pubsub:broker -c 'tests/Example/config-file.php' -v ou # running in Dockerized PHP ./composer pubsub-server
# Server terminal running
➜ Using JsonEventSerializer serializer
➜ Verbose mode enabled
✔ The publish/subscriber server has been started in tcp://localhost:7703
Ready! The event server is running on port 7703, which will be available to receive events.
Note: while the server is running, the current terminal will be in "watch" mode, waiting to receive events. The "-v" option activates the "verbose" mode, so that whenever an event is received, the server will notify the running terminal.
3. Send events to the server
With the server running, just open another terminal and use the command below to send some test events:
# running in local PHP ./broker pubsub:client-test -d localhost -p 7703 -v ou # running in Dockerized PHP ./composer pubsub-client
The two terminals will react to the sending of events, showing the corresponding information:
# Terminal where events were sent
✔ Publish event of type 'EventOne' to channel 'channel-vormir' in tcp://localhost:7703
✔ Publish event of type 'EventTwo' to channel 'channel-vormir' in tcp://localhost:7703
✔ Publish event of type 'EventTwo' to channel 'channel-mordor' in tcp://localhost:7703
✔ Publish event of type 'EventTwo' to channel 'channel-greenville' in tcp://localhost:7703
➜ Published Events
➜ Used memory: 1921928
# Server terminal that received the events
➜ [2022-06-03 17:06:09]: Message of type 'EventOne' received on channel 'channel-vormir'
Message dispatched to SubscriberOne
Message dispatched to SubscriberTwo
➜ [2022-06-03 17:06:09]: Message of type 'EventTwo' received on channel 'channel-vormir'
Message dispatched to SubscriberTwo
...
Características
- Coded with best practices and maximum quality;
- Well documented and IDE friendly;
- Made with TDD (Test Driven Development);
- Implemented with unit tests using PHPUnit;
- Made with ❤️ & ☕.
Credits
统计信息
- 总下载量: 584
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 0
- 点击次数: 1
- 依赖项目数: 2
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2022-11-10