1

我正在尝试使用 ActiveMQ 5.8.0 和 PHP Stomp 扩展来实现代理重新交付。但这并没有按预期工作。

回滚消息的 PHP 订阅者

define('QUEUE_NAME', '/queue/Task.Test');

$stomp = new Stomp();

$stomp->subscribe(QUEUE_NAME, array(
    'activemq.prefetchSize' => 10,
));

while (true) {

    $tid = uniqid('tid');
    $stomp->begin($tid);

    try {
        $frame = $stomp->readFrame();
        if ($frame) {
            print_r($frame->headers);
            $stomp->ack($frame->headers['message-id'], array('transaction' => $tid));
            echo "Get message {$frame->headers['message-id']}, rollback it", PHP_EOL;
            $stomp->abort($tid);
        } else {
           $stomp->commit($tid);
        }
    } catch (StompException $e) {
        $stomp->abort($tid);
    }
}

ActiveMQ 配置(调度程序已启用):

    <plugins>
        <redeliveryPlugin fallbackToDeadLetter="true" sendToDlqIfMaxRetriesExceeded="true">
            <redeliveryPolicyMap>
                <redeliveryPolicyMap>
                    <redeliveryPolicyEntries>
                        <!-- a destination specific policy -->
                        <redeliveryPolicy queue=">" maximumRedeliveries="2" redeliveryDelay="10000" />
                    </redeliveryPolicyEntries>
                    <!-- the fallback policy for all other destinations -->
                    <defaultEntry>
                        <redeliveryPolicy maximumRedeliveries="2" initialRedeliveryDelay="5000" redeliveryDelay="10000" />
                    </defaultEntry>
                </redeliveryPolicyMap>
            </redeliveryPolicyMap>
        </redeliveryPlugin>
    </plugins>

使用该配置订阅者接收所有消息并将它们回滚,因此它们返回队列,但我希望它们在延迟后重新传递。ACK 有特殊状态:“poison ack”,但我不知道如何指定。

如何在代理端启用重新交付?

4

1 回答 1

2

实际上,重新交付需要在STOMP 协议版本 >=1.1中定义的 NACK 命令。PHP Stomp 客户端仅支持 1.0 版本,因此无法为此扩展启用重新交付。nack()但是,使用方法和标头处理扩展 Stomp 类很容易。希望这些信息对某人有所帮助。

于 2013-12-18T14:56:43.980 回答