php-mq / server
PHP message queue server
dev-master
2018-01-01 21:48 UTC
Requires
- php: >=7.1
- php-mq/protocol: dev-master
- php-mq/stream: dev-master
- psr/log: ~1.0.2
- roave/security-advisories: dev-master
Requires (Dev)
- tm/tooly-composer-script: ^1.0
This package is auto-updated.
Last update: 2024-11-10 04:48:18 UTC
README
PHPMQ\MessageQueueServer
A lightweight PHP message queue
At the moment this is a proof-of-concept implementation.
Description
This implementation aims to implement the following requirements.
For details of the client-endpoint-communication see the message protocol documentation.
Message endpoint
- Establish a communication endpoint via network or unix domain socket. (both should be possible)
- Accept connections to that endpoint and constantly receive messages from clients
Message senders
- Can connect/disconnect to/from the message endpoint
- Can request a named queue
- Can send arbitrary amount of messages to the queue
Message queues
- Create named queues as they are requested by the sender
- Flush queues on demand
- Releases acknowledged messages
- Give status feedback on existing queues
- First in - First out
Message persistence
- Persist incoming messages to an SQLite3 memory storage
- Mirror the SQLite3 memory storage to a SQLite3 file storage to keep messages beyond a reboot
- Mirror to file storage in background to keep persistence fast
Message consumers
- Can connect/disconnect to/from the message endpoint
- Can consume a variable amount of messages from one or multiple named queues
- Must acknowledge the consumed message to release it from the queue
Message distribution
- Distribute messages equally to all connected consumers
- Reallocates distribution on dis-/connect of consumers
- Dispatches a message to other consumer, if message was dispatched but not acknowledged and the respective consumer disconnected
Contributing
Contributions are welcome and will be fully credited. Please see the contribution guide for details.