marko/pubsub-pgsql
最新稳定版本:0.6.0
Composer 安装命令:
composer require marko/pubsub-pgsql
包简介
PostgreSQL pub/sub driver for Marko Framework
README 文档
README
Zero-infrastructure pub/sub via PostgreSQL LISTEN/NOTIFY -- real-time messaging using the database you already have, no Redis required.
Overview
marko/pubsub-pgsql implements the marko/pubsub contracts using PostgreSQL's native LISTEN/NOTIFY mechanism. PgSqlPublisher issues NOTIFY and PgSqlSubscriber issues LISTEN over a persistent async connection powered by amphp/postgres. Because PostgreSQL is already a common dependency, this driver lets you add real-time messaging with no additional infrastructure.
Note: PostgreSQL does not support pattern-based subscriptions. Calling psubscribe() throws PubSubException. Use marko/pubsub-redis if you need pattern matching.
Installation
composer require marko/pubsub-pgsql
This automatically installs marko/pubsub and marko/amphp.
Usage
The module binding wires PublisherInterface → PgSqlPublisher and SubscriberInterface → PgSqlSubscriber automatically. Type-hint against the interfaces in your services.
use Marko\PubSub\Message; use Marko\PubSub\PublisherInterface; use Marko\PubSub\SubscriberInterface; // Publishing -- issues a PostgreSQL NOTIFY $publisher->publish( channel: 'orders', message: new Message( channel: 'orders', payload: json_encode(['id' => $order->id, 'status' => 'placed']), ), ); // Subscribing -- issues a PostgreSQL LISTEN $subscription = $subscriber->subscribe('orders'); foreach ($subscription as $message) { $data = json_decode($message->payload, true); } $subscription->cancel();
Publish configuration in config/pubsub-pgsql.php:
return [ 'host' => '127.0.0.1', 'port' => 5432, 'user' => 'postgres', 'password' => '', 'database' => 'app', ];
API Reference
PgSqlPublisher
Implements PublisherInterface. Applies the configured channel prefix and issues a PostgreSQL NOTIFY.
public function publish(string $channel, Message $message): void;
PgSqlSubscriber
Implements SubscriberInterface. Applies the configured channel prefix and issues a PostgreSQL LISTEN for each channel.
public function subscribe(string ...$channels): Subscription; public function psubscribe(string ...$patterns): Subscription; // throws PubSubException
PgSqlSubscription
Iterates incoming NOTIFY payloads as Message instances. Implements Subscription (IteratorAggregate<int, Message>).
public function getIterator(): Generator; // yields Message public function cancel(): void;
PgSqlPubSubConnection
Manages the persistent amphp/postgres connection used by both the publisher and subscriber.
Documentation
Full usage, API reference, and examples: marko/pubsub-pgsql
统计信息
- 总下载量: 39
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 0
- 点击次数: 1
- 依赖项目数: 0
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2026-03-24