Yandex Cloud
Поиск
Связаться с намиПодключиться
  • Документация
  • Блог
  • Все сервисы
  • Статус работы сервисов
    • Популярные
    • Инфраструктура и сеть
    • Платформа данных
    • Контейнеры
    • Инструменты разработчика
    • Бессерверные вычисления
    • Безопасность
    • Мониторинг и управление ресурсами
    • Машинное обучение
    • Бизнес-инструменты
  • Все решения
    • По отраслям
    • По типу задач
    • Экономика платформы
    • Безопасность
    • Техническая поддержка
    • Каталог партнёров
    • Обучение и сертификация
    • Облако для стартапов
    • Облако для крупного бизнеса
    • Центр технологий для общества
    • Облако для интеграторов
    • Поддержка IT-бизнеса
    • Облако для фрилансеров
    • Обучение и сертификация
    • Блог
    • Документация
    • Контент-программа
    • Мероприятия и вебинары
    • Контакты, чаты и сообщества
    • Идеи
    • Истории успеха
    • Тарифы Yandex Cloud
    • Промоакции и free tier
    • Правила тарификации
  • Документация
  • Блог
Проект Яндекса
© 2025 ООО «Яндекс.Облако»
Все решения
    • Все решения для Cloud Functions
    • Устранение ошибки `CORS` при обращении к API SpeechKit, Vision OCR или Translate из фронтенда веб-приложения
    • Устранение ошибок с HTTP 499 при работе облачной функции или контейнера Serverless Containers
    • Устранение проблем с подключением к YDB из кода функции Cloud Functions
    • Устранение ошибки `No node can serve the request (Too many reschedules)`
    • Устранение ошибки `No node can serve the request (concurrent requests exceeded)`
    • Как подключиться к функции из MDB
    • Как настроить статический IP-адрес
    • Как работать с облачными функциями асинхронно
    • Как настроить аутентификацию для `boto3`

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

  • Описание сценария
  • Решение
  1. Cloud Functions
  2. Как работать с облачными функциями асинхронно

Как работать с облачными функциями асинхронно

Статья создана
Yandex Cloud
Обновлена 16 августа 2024 г.
  • Описание сценария
  • Решение

Описание сценарияОписание сценария

  • Необходимо реализовать асинхронный вызов облачной функции;
  • Необходимо закрыть соединение и отдать ответ функции, не дожидаясь окончания работы облачной функции;
  • Необходимо сделать так, чтобы функция работала более 10 минут.

РешениеРешение

Напрямую реализовать асинхронные вызовы в Cloud Functions не получится - пока контейнер Serverless Containers или облачная функция выполняются, они не могут вернуть HTTP-ответ. Как только контейнер или функция вернут ответ, их выполнение завершается.

В качестве альтернативного сценария реализовать такой пайплайн возможно при помощи сервисов API Gateway и Data Streams.

  1. Cоздайте шлюз API Gateway в качестве обработчика вебхука, к которому будет подключен поток данных Data Streams.
  2. Настройте триггер для потока данных, который будет вызывать контейнер или функцию.

В этом случае шлюз API Gateway вернет код ответа HTTP 200 OK, а контейнер или функция асинхронно обработают вызов.

Важно

Выполнение кода внутри контейнера Serverless Containers или облачной функции не может выполняться дольше 10 минут, в том числе с использованием триггеров. Мы пишем об этом в документации сервисов.

Если есть возможность разбить вычисление на несколько вызовов, вы можете собрать асинхронный конвейер: когда первый вызов производит вычисления и вызывает следующую стадию через тот же самый поток данных Data Streams. Однако следует учитывать, что в этом случае второй вызов может быть обработан в другом экземпляре контейнера или облачной функции.

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

Предыдущая
Как настроить статический IP-адрес
Следующая
Как настроить аутентификацию для `boto3`
Проект Яндекса
© 2025 ООО «Яндекс.Облако»