(PECL stomp >= 0.1.0)
Stomp::commit -- stomp_commit — Выполняет текущую транзакцию
Объектно-ориентированный стиль (метод):
$transaction_id
[, array $headers
] ) : boolПроцедурный стиль:
$link
, string $transaction_id
[, array $headers
] ) : boolВыполняет текущую транзакцию.
link
Только для процедурного стиля: Идентификатор соединения stomp, полученный из stomp_connect().
transaction_id
Идентификатор транзакции.
headers
Ассоциативный массив, содержащий дополнительные заголовки (пример: receipt).
Возвращает TRUE
в случае успешного завершения или FALSE
в случае возникновения ошибки.
Stomp асинхронен по своей сути. Синхронная связь может быть реализована добавлением receipt-заголовка. Это заставит методы ничего не возвращать, пока сервер не подтвердит получение сообщения или не будет достигнут таймаут сообщения.
Пример #1 Объектно-ориентированный стиль
<?php
/* подключение */
try {
$stomp = new Stomp('tcp://localhost:61613');
} catch(StompException $e) {
die('Ошибка соединения: ' . $e->getMessage());
}
/* Начало транзакции */
$stomp->begin('t1');
/* отправка сообщения в очередь */
$stomp->send('/queue/foo', 'bar', array('transaction' => 't1'));
/* выполнение транзакции */
$stomp->commit('t1');
/* закрытие подключения */
unset($stomp);
?>
Пример #2 Процедурный стиль
<?php
/* подключение */
$link = stomp_connect('tcp://localhost:61613');
/* проверка подключения */
if (!$link) {
die('Ошибка соединения: ' . stomp_connect_error());
}
/* Начало транзакции */
stomp_begin($link, 't1');
/* Отправка сообщения в очередь 'foo' */
stomp_send($link, '/queue/foo', 'bar', array('transaction' => 't1'));
/* Выполнение транзакции */
stomp_commit($link, 't1');
/* Закрытие изменения */
stomp_close($link);
?>