Pub/Sub Google Cloud — это глобально распределенная шина сообщений, которая автоматически масштабируется по мере необходимости. Вы можете создать функцию, которая обрабатывает события Pub/Sub используя functions.pubsub
.
Запустить функцию публикации/подписки
Вы можете активировать функцию всякий раз, когда новое сообщение Pub/Sub отправляется в определенную тему. Вы должны указать имя темы Pub/Sub , которую вы хотите активировать, и установить событие в обработчике событий onPublish()
:
exports.helloPubSub = functions.pubsub.topic('topic-name').onPublish((message) => { // ... });
Доступ к полезной нагрузке сообщения pub/sub {:#access-pub/sub}
Полезная нагрузка для сообщения Pub/Sub доступна из объекта Message
, возвращенного вашей функции. Для сообщений с JSON в теле сообщения Pub/Sub Firebase SDK для Cloud Functions имеет вспомогательное свойство для декодирования сообщения. Например, вот сообщение, опубликованное с простой полезной нагрузкой JSON:
gcloud pubsub topics publish topic-name --message '{"name":"Xenia"}'
Вы можете получить доступ к полезной нагрузке данных JSON через свойство json
:
// Get the `name` attribute of the PubSub message JSON body. let name = null; try { name = message.json.name; } catch (e) { functions.logger.error('PubSub message was not JSON', e); }
Другие полезные данные, отличные от JSON, содержатся в сообщении Pub/Sub в виде строк в кодировке Base64 в объекте сообщения. Чтобы прочитать сообщение, подобное следующему, вы должны декодировать строку в кодировке Base64, как показано:
gcloud pubsub topics publish topic-name --message 'MyMessage'
// Decode the PubSub Message body. const messageBody = message.data ? Buffer.from(message.data, 'base64').toString() : null;
Атрибуты сообщения доступа {:#access-message}
Сообщение Pub/Sub может быть отправлено с атрибутами данных, установленными в команде публикации. Например, вы можете опубликовать сообщение с атрибутом name
:
gcloud pubsub topics publish topic-name --attribute name=Xenia
Вы можете прочитать такие атрибуты из Message.attributes
:
// Get the `name` attribute of the message. const name = message.attributes.name;
Вы можете заметить, что некоторые основные данные, такие как идентификатор сообщения или время публикации сообщения, недоступны в Message.attributes
. Чтобы обойти эту проблему, вы можете получить доступ к этим сведениям в EventContext
триггерного события. Например:
exports.myFunction = functions.pubsub.topic('topic1').onPublish((message, context) => {
console.log('The function was triggered at ', context.timestamp);
console.log('The unique ID for the event is', context.eventId);
});