Сравнение версий облачных функций

Существует две версии Cloud Functions for Firebase :

  • Cloud Functions (2-го поколения) , который развертывает ваши функции как службы в Cloud Run , позволяя вам запускать их с помощью Eventarc и Pub/Sub .
  • Cloud Functions (1-го поколения) , оригинальная версия функций с ограниченными триггерами событий и возможностями настройки.

Мы рекомендуем вам по возможности выбирать Cloud Functions (2-го поколения) для новых функций. Однако мы планируем продолжить поддержку Cloud Functions (1-го поколения).

На этой странице описываются функции, представленные в Cloud Functions , и проводится сравнение двух версий продукта.

Cloud Functions (2-го поколения)

Cloud Functions — это решение Firebase «функции как услуга» нового поколения. Cloud Functions (2-го поколения), созданное на основе Cloud Run и Eventarc , обеспечивает улучшенную инфраструктуру и более широкий охват событий в Cloud Functions , включая:

  • Создано на основе Cloud Run : функции создаются с помощью Cloud Build и развертываются как сервисы Cloud Run используя среду выполнения Cloud Run по умолчанию. Это даёт вам возможность настраивать функцию так же, как сервис Cloud Run . Чтобы узнать о возможностях настройки сервиса, таких как ограничения памяти , переменные среды и т. д., обратитесь к документации Cloud Run
  • Более длительное время обработки запросов : выполнение более длительных рабочих нагрузок, таких как обработка больших потоков данных из Cloud Storage или BigQuery .
  • Большие размеры экземпляров : выполнение больших объемов вычислений, ресурсоемких и параллельных рабочих нагрузок в оперативной памяти.
  • Улучшенная параллельность : обработка нескольких одновременных запросов с помощью одного экземпляра функции для минимизации холодных запусков и уменьшения задержек.
  • Управление трафиком : разделение трафика между различными версиями функций или откат функции к предыдущей версии.
  • Интеграция Eventarc : встроенная поддержка триггеров Eventarc , позволяющая использовать более 90 источников событий, поддерживаемых Eventarc , в Cloud Functions .
  • Расширенная поддержка CloudEvents : поддержка отраслевого стандарта CloudEvents во всех языковых средах выполнения, обеспечивающая единообразный опыт разработки.

Подробности смотрите в сравнительной таблице .

Поскольку Cloud Functions развертывает функции как сервисы в Cloud Run , Cloud Functions использует квоты и ограничения ресурсов совместно с Cloud Run . См. раздел «Квоты» .

Сравнительная таблица

Особенность Cloud Functions (1-го поколения) Cloud Functions
Реестр изображений Container Registry или Artifact Registry Только Artifact Registry
Запрос времени ожидания До 9 минут
  • До 60 минут для HTTP-функций
  • До 9 минут для функций, запускаемых событиями
Размер экземпляра До 8 ГБ ОЗУ с 2 виртуальными ЦП До 16 ГБ ОЗУ с 4 виртуальными ЦП
Параллелизм 1 одновременный запрос на экземпляр функции До 1000 одновременных запросов на экземпляр функции

Цены

Информацию о ценах см. в разделе Тарифные планы Firebase .

Если вы используете Cloud Functions , вы можете просмотреть свои расходы, связанные только с Cloud Functions следующим образом:

  1. Перейдите на страницу отчетов Cloud Billing в консоли Google Cloud.
  2. При появлении запроса выберите платежный аккаунт, связанный с вашим проектом Google Cloud.
  3. На панели Фильтры в разделе Метки добавьте фильтр меток с ключом goog-managed-by и значением cloudfunctions .

Ограничения

Cloud Functions for Firebase (2-го поколения) не поддерживает события Analytics .

Хотя Cloud Functions for Firebase (2-го поколения) поддерживает события блокировки аутентификации, он не поддерживает тот же набор базовых событий Authentication , что и 1-е поколение.

Однако, поскольку функции 1-го и 2-го поколений могут сосуществовать бок о бок в одном исходном файле, вы по-прежнему можете разрабатывать и развертывать Analytics и базовые триггеры Authentication в 1-м поколении вместе с функциями 2-го поколения.