marko/pubsub 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

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

marko/pubsub

最新稳定版本:0.6.0

Composer 安装命令:

composer require marko/pubsub

包简介

Pub/sub interfaces and value objects for Marko Framework

README 文档

README

Real-time publish/subscribe messaging contracts — type-hint against a stable interface and swap drivers without changing application code.

Overview

marko/pubsub provides the core contracts for publish/subscribe messaging in Marko. It defines PublisherInterface, SubscriberInterface, Subscription, and the Message value object. The package ships no driver of its own — install a driver package such as marko/pubsub-pgsql or marko/pubsub-redis to get a concrete implementation.

Installation

composer require marko/pubsub

Usage

Type-hint against the interfaces in your services and let the container inject the active driver.

use Marko\PubSub\Message;
use Marko\PubSub\PublisherInterface;
use Marko\PubSub\SubscriberInterface;

// Publishing
$publisher->publish(
    channel: 'orders',
    message: new Message(
        channel: 'orders',
        payload: json_encode(['id' => $order->id, 'status' => 'placed']),
    ),
);

// Subscribing
$subscription = $subscriber->subscribe('orders');

foreach ($subscription as $message) {
    $data = json_decode($message->payload, true);
}

// Cancel when done
$subscription->cancel();

// Pattern subscriptions (Redis driver only)
$subscription = $subscriber->psubscribe('orders.*');

Configuration keys used by driver packages:

// config/pubsub.php
return [
    'driver' => 'redis',   // active driver
    'prefix' => '',        // optional channel prefix applied by all drivers
];

API Reference

PublisherInterface

interface PublisherInterface
{
    public function publish(string $channel, Message $message): void;
}

SubscriberInterface

interface SubscriberInterface
{
    public function subscribe(string ...$channels): Subscription;
    public function psubscribe(string ...$patterns): Subscription;
}

Message

readonly class Message
{
    public function __construct(
        public string $channel,
        public string $payload,
        public ?string $pattern = null,
    ) {}
}

Subscription

interface Subscription extends IteratorAggregate
{
    /** @return Generator<int, Message> */
    public function getIterator(): Generator;
    public function cancel(): void;
}

PubSubException

Named constructors for all failure scenarios:

Factory method When thrown
connectionFailed(string $driver, string $reason) Driver cannot connect
subscriptionFailed(string $channel, string $reason) Subscribe call fails
publishFailed(string $channel, string $reason) Publish call fails
patternSubscriptionNotSupported(string $driver) psubscribe() on a driver that does not support patterns

Documentation

Full usage, API reference, and examples: marko/pubsub

统计信息

  • 总下载量: 46
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 2
  • 依赖项目数: 2
  • 推荐数: 1

GitHub 信息

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

其他信息

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

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固