定制 octo-php/symfony-messenger 二次开发

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

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

octo-php/symfony-messenger

最新稳定版本:v0.1.2

Composer 安装命令:

composer require octo-php/symfony-messenger

包简介

Symfony Messenger transport for the Async PHP Platform — in-process message passing via bounded OpenSwoole channels with backpressure.

README 文档

README

Transport Symfony Messenger in-process pour la plateforme async PHP — message passing via channels OpenSwoole bornés avec backpressure.

Installation

composer require octo-php/symfony-messenger

Configuration

DSN

# config/packages/messenger.yaml
framework:
    messenger:
        transports:
            async:
                dsn: 'openswoole://default'
                options:
                    channel_capacity: 100
                    send_timeout: 5.0

Variables d'environnement

Variable Type Défaut Description
OCTOP_SYMFONY_MESSENGER_CHANNEL_CAPACITY int 100 Capacité du channel borné (backpressure)
OCTOP_SYMFONY_MESSENGER_CONSUMERS int 1 Nombre de coroutines consommatrices par worker
OCTOP_SYMFONY_MESSENGER_SEND_TIMEOUT float (s) 5.0 Timeout d'envoi quand le channel est plein

Via le bundle

# config/packages/octo.yaml
octo:
    messenger:
        channel_capacity: 100
        consumers: 1
        send_timeout: 5.0

Fonctionnement

Le transport utilise un channel OpenSwoole borné pour le message passing in-process :

  • send() : push le message dans le channel. Si le channel est plein, la coroutine yield (backpressure) jusqu'à ce qu'un espace soit disponible ou que le timeout soit atteint.
  • get() : pop un message du channel avec un poll timeout de 1s.
  • ack() : no-op (in-process, pas de broker externe).
  • reject() : log warning.

Les consumers sont spawnés au boot du worker via structured concurrency (TaskGroup) et annulés proprement au shutdown (pas de coroutines zombies).

Métriques

Métrique Type Description
messenger_messages_sent_total counter Messages envoyés
messenger_messages_consumed_total counter Messages consommés
messenger_channel_size gauge Taille courante du channel

Limitations

Transport in-process uniquement

Ce transport est non distribué et non durable :

  • Les messages sont stockés en mémoire dans le channel OpenSwoole du worker
  • Le channel est isolé par worker : les messages ne sont pas partagés entre workers
  • Les messages non consommés au moment du restart du worker sont perdus

Cas d'usage adaptés

  • Fire-and-forget (notifications, logs asynchrones)
  • Background jobs légers (envoi d'emails, cache warming)
  • Traitement asynchrone intra-requête

Cas d'usage non adaptés

Pour le messaging durable, distribué ou critique, utiliser les transports externes standard Symfony :

  • AMQP (RabbitMQ)
  • Redis
  • Doctrine

Retry et failure transport

Les mécanismes standard de retry et failure transport de Symfony Messenger s'appliquent normalement :

framework:
    messenger:
        transports:
            async:
                dsn: 'openswoole://default'
                retry_strategy:
                    max_retries: 3
                    delay: 1000
                    multiplier: 2

        failure_transport: failed

        transports:
            failed:
                dsn: 'doctrine://default?queue_name=failed'

Pour les messages critiques, configurez un failure transport durable (Doctrine, Redis) afin de ne pas perdre les messages en cas de restart.

Licence

MIT

统计信息

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

GitHub 信息

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

其他信息

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

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固