layout | title | parent | nav_order |
---|---|---|---|
default |
STOMP |
Transports |
3 |
{% include support.md %}
$ composer require enqueue/stomp
<?php
use Enqueue\Stomp\StompConnectionFactory;
// connects to localhost
$factory = new StompConnectionFactory();
// same as above
$factory = new StompConnectionFactory('stomp:');
// same as above
$factory = new StompConnectionFactory([]);
// connect via stomp to RabbitMQ (default) - the topic names are prefixed with /exchange
$factory = new StompConnectionFactory('stomp+rabbitmq:');
// connect via stomp to ActiveMQ - the topic names are prefixed with /topic
$factory = new StompConnectionFactory('stomp+activemq:');
// connect to stomp broker at example.com port 1000 using
$factory = new StompConnectionFactory([
'host' => 'example.com',
'port' => 1000,
'login' => 'theLogin',
]);
// same as above but given as DSN string
$factory = new StompConnectionFactory('stomp://example.com:1000?login=theLogin');
$context = $factory->createContext();
// if you have enqueue/enqueue library installed you can use a factory to build context from DSN
$context = (new \Enqueue\ConnectionFactoryFactory())->create('stomp:')->createContext();
<?php
/** @var \Enqueue\Stomp\StompContext $context */
$message = $context->createMessage('Hello world!');
$fooTopic = $context->createTopic('foo');
$context->createProducer()->send($fooTopic, $message);
<?php
/** @var \Enqueue\Stomp\StompContext $context */
$message = $context->createMessage('Hello world!');
$fooQueue = $context->createQueue('foo');
$context->createProducer()->send($fooQueue, $message);
<?php
/** @var \Enqueue\Stomp\StompContext $context */
$fooQueue = $context->createQueue('foo');
$consumer = $context->createConsumer($fooQueue);
$message = $consumer->receive();
// process a message
$consumer->acknowledge($message);
// $consumer->reject($message);