Naar console

配额和限制

与其他 Firebase 服务一样,Cloud Functions for Firebase 也提供免费的“Spark”方案和拥有固定价格的“Flame”方案,其中包含适用于开发或小规模部署的配额。如需了解 Spark 和 Flame 配额与限制的详细信息,请参阅定价方案。本页面的其余部分详细介绍了“Blaze”方案可扩容且基于用量的限制。

Google Cloud Functions 的配额包含 3 个方面:

  • 资源限制

    这些限制会影响您的函数可以使用的资源总量。

  • 时间限制

    这些限制会影响函数的运行时长。

  • 速率限制

    这些限制会影响您调用 Cloud Functions API 的速率和/或使用资源的速率。您可以将速率配额视为“一段时间内的资源数量”。

下面将更详细地介绍各种不同类型的限制。

资源限制

配额 说明 限制 可以增加 范围
函数的数量 每个项目可以部署的函数总数 1000 个 每个项目
部署大小上限 单个函数部署的大小上限 源文件为 100MB(压缩后)。
源文件和模块一共 500MB(未压缩)。
每个函数
未压缩 HTTP 请求的大小上限 在一次 HTTP 请求中发送到 HTTP 函数的数据 10MB 每次调用
未压缩 HTTP 响应的大小上限 在一次 HTTP 响应中从 HTTP 函数发送的数据 10MB 每次调用
后台函数的事件大小上限 在事件中发送到后台函数的数据 10MB 每个事件
函数内存的大小上限 函数可以使用的内存量 2048MB 每个函数

时间限制

配额 说明 限制 可以增加 范围
函数运行时长上限 函数在被强制终止之前可以运行的最长时间 540 秒 每次调用
构建时间上限 所有构建操作可以执行的最长时间。函数构建发生在部署过程中。 每天 120 分钟 每个项目

速率限额

配额 说明 限制 可以增加 范围
每秒函数调用次数 一秒钟内函数调用的次数。如果超过此配额,所有函数都将暂停,直到下一个配额周期到来 每 100 秒 1 亿次 每个区域
GHz-秒 所有正在运行的函数使用的 GHz-秒数量。例如,一个使用 256MB 内存(对应于 400MHz CPU,具体请参阅计算时间定价)的函数运行 1 秒钟,将会用掉 0.4 GHz-秒。系统会将函数运行的时长向上取整到 100 毫秒的倍数。 每 100 秒 10 万 GHz-秒 每个区域
每日 GHz-秒数量 每天所有运行的函数使用的 GHz-秒数量。 每天 1000 万 GHz-秒 每个项目
API 调用次数(读取) 通过 Cloud Functions API 描述或列出函数的调用次数 每 100 秒 5000 次 每个项目
API 调用次数(写入) 通过 Cloud Functions API 部署或删除函数的调用次数 每 100 秒 80 次 1 每个项目
API 调用次数(调用) 对“call”API 的调用次数 每 100 秒 16 次 2 每个项目
出站套接字数据量 从所有正在运行的函数传出的数据量,不包括 HTTP 响应数据 每 100 秒 10 GB 每个区域

扩容

通过 HTTP 调用的 Cloud Functions 函数可以快速扩容以处理传入流量,而后台函数的扩容速度则要慢一些。函数的扩容能力取决于多种因素,包括:

  • 函数执行完毕所需的时间(短期运行的函数通常可以纵向扩容以处理更多的并发请求)。
  • 函数在冷启动时初始化所用的时间。
  • 速率限制(见上文)。
  • 函数的错误率。
  • 暂时性因素,例如区域负载和数据中心容量。
后台函数有如下所述的额外限制。这些限制不适用于 HTTP 函数

后台函数的额外配额

配额 说明 限制 可以增加 范围
最大并发调用次数 单个函数的最大并发调用次数
例如:如果处理每个事件需要 100 秒,则调用速率将被限制为平均每秒 10 次
1000 次 每个函数
最大调用速率 单个函数处理事件的最大速率
例如:如果处理一个事件需要 100 毫秒,那么即使只并行处理平均 100 个请求,调用速率也将被限制为每秒 1000 次
每秒 1000 次 每个函数
并发事件数据大小上限 单个函数的并发调用传入事件总大小上限
例如:如果事件大小为 1MB 并且处理这些事件需要 10 秒钟,则平均速率限制将是每秒 1 个事件,这是因为只有在处理完前 10 个事件中的一个事件之后,函数才会处理第 11 个事件
10MB 每个函数
传入事件最大吞吐量 单个函数的传入事件最大吞吐量
例如:如果事件大小为 1MB,那么即使函数在 100 毫秒内执行完毕,调用速率也最多只能是每秒 10 次
每秒 10MB 每个函数

达到配额限制时

当某个函数使用完所有已分配的资源时,直到系统刷新或增加了配额后,函数才能再使用该资源。这可能意味着在此之前,您的函数和同一项目中的所有其他函数都将无法工作。当其中一个资源超过配额并且函数无法执行时,该函数将返回一个 HTTP 500 错误代码。

如需将配额增加到超出此处所列默认值的水平,请转到 Cloud Functions 配额页面,选择要修改的配额,然后点击修改配额,在出现提示时提供用户信息,并为您选择的每项配额输入新的配额限制。

Firebase CLI 部署的配额限制

对于 Firebase CLI 部署的每个函数,会涉及以下类型的速率和时间限制:

  • API 调用(读取)- 每个部署调用 1 次,无论有多少个函数
    • 限制:每 100 秒 5000 次
  • API 调用(写入)- 每个函数调用 1 次
    • 限制:每 100 秒 80 次
  • 编译时间上限 - 每个函数几分钟,具体取决于大小
    • 限制:每天 120 分钟

另请参阅 Firebase CLI 参考