定制 marko/pubsub-pgsql 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

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 PublisherInterfacePgSqlPublisher and SubscriberInterfacePgSqlSubscriber 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

GitHub 信息

  • Stars: 0
  • Watchers: 0
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2026-03-24

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固