Yandex Cloud
Поиск
Связаться с намиПодключиться
  • Документация
  • Блог
  • Все сервисы
  • Статус работы сервисов
    • Популярные
    • Инфраструктура и сеть
    • Платформа данных
    • Контейнеры
    • Инструменты разработчика
    • Бессерверные вычисления
    • Безопасность
    • Мониторинг и управление ресурсами
    • Машинное обучение
    • Бизнес-инструменты
  • Все решения
    • По отраслям
    • По типу задач
    • Экономика платформы
    • Безопасность
    • Техническая поддержка
    • Каталог партнёров
    • Обучение и сертификация
    • Облако для стартапов
    • Облако для крупного бизнеса
    • Центр технологий для общества
    • Облако для интеграторов
    • Поддержка IT-бизнеса
    • Облако для фрилансеров
    • Обучение и сертификация
    • Блог
    • Документация
    • Контент-программа
    • Мероприятия и вебинары
    • Контакты, чаты и сообщества
    • Идеи
    • Истории успеха
    • Тарифы Yandex Cloud
    • Промоакции и free tier
    • Правила тарификации
  • Документация
  • Блог
Проект Яндекса
© 2025 ООО «Яндекс.Облако»
Yandex Serverless Containers
  • Сопоставление с другими сервисами Yandex Cloud
    • Все инструкции
    • Получение IAM-токена сервисного аккаунта с помощью контейнера
      • Создать таймер
      • Создать триггер для Message Queue
      • Создать триггер для Object Storage
      • Создать триггер для Container Registry
      • Создать триггер для Cloud Logging
      • Создать триггер для бюджетов
      • Создать триггер для Data Streams
      • Создать триггер для почты
    • Просмотр операций с ресурсами сервиса
  • Управление доступом
  • Правила тарификации
  • Справочник Terraform
  • Аудитные логи Audit Trails
  • История изменений
  • Вопросы и ответы

В этой статье:

  • Перед началом работы
  • Создать триггер
  • Проверить результат
  • См. также
  1. Пошаговые инструкции
  2. Создание триггера
  3. Создать триггер для Message Queue

Создать триггер для Message Queue, который передает сообщения в контейнер Serverless Containers

Статья создана
Yandex Cloud
Улучшена
Обновлена 21 апреля 2025 г.
  • Перед началом работы
  • Создать триггер
  • Проверить результат
  • См. также

Создайте триггер для очереди сообщений сервиса Message Queue и обрабатывайте их с помощью контейнера Serverless Containers.

Важно

  • Триггер можно создать только для стандартной очереди сообщений.
  • Триггер должен находиться в одном облаке с очередью, из которой он читает сообщения.
  • Для одной очереди сообщений можно создать только один триггер.

Перед началом работыПеред началом работы

Для создания триггера вам понадобятся:

  • Контейнер, который триггер будет вызывать. Если у вас нет контейнера:

    • Создайте контейнер.
    • Создайте ревизию контейнера.
  • Сервисные аккаунты с правами:

    • на вызов контейнера;
    • на чтение из очереди, из которой триггер будет принимать сообщения.

    Вы можете использовать один и тот же сервисный аккаунт или разные. Если у вас нет сервисного аккаунта, создайте его.

  • Очередь сообщений, из которой триггер будет принимать сообщения. Если у вас нет очереди, создайте ее.

Создать триггерСоздать триггер

Примечание

Триггер начинает работать в течение 5 минут после создания.

Консоль управления
CLI
Terraform
API
  1. В консоли управления перейдите в каталог, в котором хотите создать триггер.

  2. Откройте сервис Serverless Containers.

  3. На панели слева выберите Триггеры.

  4. Нажмите кнопку Создать триггер.

  5. В блоке Базовые параметры:

    • Введите имя и описание триггера.
    • В поле Тип выберите Message Queue.
    • В поле Запускаемый ресурс выберите Контейнер.
  6. В блоке Настройки сообщений Message Queue выберите очередь сообщений и сервисный аккаунт с правами на чтение из нее.

  7. В блоке Настройки группирования сообщений укажите:

    • Время ожидания, с. Допустимые значения от 0 до 20 секунд, значение по умолчанию — 10 секунд.
    • Размер группы. Допустимые значения от 1 до 1000, значение по умолчанию — 1.

    Триггер группирует сообщения не дольше указанного времени ожидания и отправляет их в контейнер. Число сообщений при этом не превышает указанный размер группы.

  8. В блоке Настройки контейнера выберите его и сервисный аккаунт, от имени которого он будет вызываться.

  9. Нажмите кнопку Создать триггер.

Если у вас еще нет интерфейса командной строки Yandex Cloud (CLI), установите и инициализируйте его.

По умолчанию используется каталог, указанный при создании профиля CLI. Чтобы изменить каталог по умолчанию, используйте команду yc config set folder-id <идентификатор_каталога>. Также для любой команды вы можете указать другой каталог с помощью параметров --folder-name или --folder-id.

Чтобы создать триггер, который вызывает контейнер, выполните команду:

yc serverless trigger create message-queue \
  --name <имя_триггера> \
  --queue <идентификатор_очереди> \
  --queue-service-account-id <идентификатор_сервисного_аккаунта> \
  --invoke-container-id <идентификатор_контейнера> \
  --invoke-container-service-account-id <идентификатор_сервисного_аккаунта> \
  --batch-size <размер_группы_сообщений> \
  --batch-cutoff <максимальное_время_ожидания>

Где:

  • --name — имя триггера.

  • --queue — идентификатор очереди.

    Чтобы узнать идентификатор очереди:

    1. В консоли управления перейдите в каталог, в котором находится очередь.
    2. Выберите сервис Message Queue.
    3. Выберите очередь.
    4. Идентификатор очереди будет в блоке Общая информация, в поле ARN.
  • --invoke-container-id — идентификатор контейнера.

  • --queue-service-account-id — идентификатор сервисного аккаунта с правами на чтение из очереди сообщений.

  • --invoke-container-service-account-id — идентификатор сервисного аккаунта с правами на вызов контейнера.

  • --batch-size — размер группы сообщений. Необязательный параметр. Допустимые значения от 1 до 1000, значение по умолчанию — 1.

  • --batch-cutoff — максимальное время ожидания. Необязательный параметр. Допустимые значения от 0 до 20 секунд, значение по умолчанию — 10 секунд. Триггер группирует сообщения не дольше batch-cutoff и отправляет их в контейнер. Число сообщений при этом не превышает batch-size.

Результат:

id: a1s5msktijh2********
folder_id: b1gmit33hgh2********
created_at: "2022-10-24T15:19:15.353909857Z"
name: ymq-trigger
rule:
  message_queue:
    queue_id: yrn:yc:ymq:ru-central1:b1gmit33ngh2********:my-mq
    service_account_id: bfbqqeo6jkh2********
    batch_settings:
      size: "1"
      cutoff: 10s
    invoke_container:
      container_id: bba5jb38o8h2********
      service_account_id: bfbqqeo6jkh2********
status: ACTIVE

Terraform позволяет быстро создать облачную инфраструктуру в Yandex Cloud и управлять ею с помощью файлов конфигураций. В файлах конфигураций хранится описание инфраструктуры на языке HCL (HashiCorp Configuration Language). При изменении файлов конфигураций Terraform автоматически определяет, какая часть вашей конфигурации уже развернута, что следует добавить или удалить.

Terraform распространяется под лицензией Business Source License, а провайдер Yandex Cloud для Terraform — под лицензией MPL-2.0.

Подробную информацию о ресурсах провайдера смотрите в документации на сайте Terraform или в зеркале.

Если у вас еще нет Terraform, установите его и настройте провайдер Yandex Cloud.

Чтобы создать триггер для Message Queue:

  1. Опишите в конфигурационном файле параметры триггера:

    resource "yandex_function_trigger" "my_trigger" {
      name = "<имя_триггера>"
      container {
        id                 = "<идентификатор_контейнера>"
        service_account_id = "<идентификатор_сервисного_аккаунта>"
      }
      message_queue {
        queue_id           = "<идентификатор_очереди>"
        service_account_id = "<идентификатор_сервисного_аккаунта>"
        batch_cutoff       = "<максимальное_время_ожидания>"
        batch_size         = "<размер_группы_сообщений>"
      }
    }
    

    Где:

    • name — имя триггера. Формат имени:

      • длина — от 2 до 63 символов;
      • может содержать строчные буквы латинского алфавита, цифры и дефисы;
      • первый символ — буква, последний — не дефис.
    • container — параметры контейнера:

      • id — идентификатор контейнера.
      • service_account_id — идентификатор сервисного аккаунта с правами на вызов контейнера.
    • message_queue — параметры триггера:

      • queue_id — идентификатор очереди.

        Чтобы узнать идентификатор очереди:

        1. В консоли управления перейдите в каталог, в котором находится очередь.
        2. Выберите сервис Message Queue.
        3. Выберите очередь.
        4. Идентификатор очереди будет в блоке Общая информация, в поле ARN.
      • service_account_id — идентификатор сервисного аккаунта с правами на чтение из очереди сообщений.

      • batch_cutoff — максимальное время ожидания. Необязательный параметр. Допустимые значения от 0 до 20 секунд, значение по умолчанию — 10 секунд. Триггер группирует сообщения не дольше batch-cutoff и отправляет их в контейнер. Число сообщений при этом не превышает batch-size.

      • batch_size — размер группы сообщений. Необязательный параметр. Допустимые значения от 1 до 1000, значение по умолчанию — 1.

    Более подробную информацию о параметрах ресурса yandex_function_trigger см. в документации провайдера.

  2. Создайте ресурсы:

    1. В терминале перейдите в папку, где вы отредактировали конфигурационный файл.

    2. Проверьте корректность конфигурационного файла с помощью команды:

      terraform validate
      

      Если конфигурация является корректной, появится сообщение:

      Success! The configuration is valid.
      
    3. Выполните команду:

      terraform plan
      

      В терминале будет выведен список ресурсов с параметрами. На этом этапе изменения не будут внесены. Если в конфигурации есть ошибки, Terraform на них укажет.

    4. Примените изменения конфигурации:

      terraform apply
      
    5. Подтвердите изменения: введите в терминале слово yes и нажмите Enter.

    Terraform создаст все требуемые ресурсы. Проверить появление ресурсов можно в консоли управления или с помощью команды CLI:

    yc serverless trigger list
    

Чтобы создать триггер для Message Queue, воспользуйтесь методом REST API create для ресурса Trigger или вызовом gRPC API TriggerService/Create.

Проверить результатПроверить результат

Serverless Containers
Message Queue

Проверьте, что триггер работает корректно. Для этого посмотрите логи контейнера, в них отображается информация о вызовах.

Проверьте, что количество сообщений в очереди уменьшается. Для этого посмотрите статистику очереди:

  1. В консоли управления откройте сервис Message Queue.
  2. Выберите очередь, для которой создали триггер.
  3. Перейдите в раздел Мониторинг. Посмотрите график Сообщений в очереди.

См. такжеСм. также

  • Создать триггер для Message Queue, который передает сообщения в функцию Cloud Functions
  • Создать триггер для Message Queue, который отправляет сообщения в WebSocket-соединения

Была ли статья полезна?

Предыдущая
Создать таймер
Следующая
Создать триггер для Object Storage
Проект Яндекса
© 2025 ООО «Яндекс.Облако»