如果您要安排函数在指定时间运行,可使用 onSchedule
处理程序创建 Pub/Sub 主题,继而使用 Cloud Scheduler 触发与该主题相关的事件。
准备工作
如需在 Firebase 项目中使用此解决方案,您的项目必须采用 Blaze 定价方案。如果您目前使用的不是 Blaze 方案,请升级您的定价方案。
虽然需要结算,但总费用是可控的,因为每项 Cloud Scheduler 作业每月费用为 0.10 美元,并且每个 Google 账号可以享受三项免费作业的福利。您可以使用 Blaze 价格计算器来根据预计使用量估算费用。
必须为项目启用 Pub/Sub 和 Cloud Scheduler API。对于大多数 Firebase 项目而言,这些 API 应该已启用;您可以在 Google Cloud Platform 控制台中验证这些 API 是否已启用。
编写预定函数
在 Cloud Functions for Firebase 中,预定逻辑位于您的函数代码中,没有特殊的部署时间要求。要创建预定函数,请使用 functions.pubsub.schedule('your schedule').onRun((context))
。例如,要使用 AppEngine cron.yaml 语法每五分钟运行一次函数,请按如下所示的方式编写相应代码:
exports.scheduledFunction = functions.pubsub.schedule('every 5 minutes').onRun((context) => {
console.log('This will be run every 5 minutes!');
return null;
});
Cloud Scheduler 支持 Unix Crontab 和 App Engine 语法。例如,如需使用 Crontab 选择要在其中运行预定函数的特定时区,您可以使用如下代码:
exports.scheduledFunctionCrontab = functions.pubsub.schedule('5 11 * * *')
.timeZone('America/New_York') // Users can choose timezone - default is America/Los_Angeles
.onRun((context) => {
console.log('This will be run every day at 11:05 AM Eastern!');
return null;
});
timeZone
的值必须是 tz 数据库中的时区名称。如需详细了解受支持的属性,请参阅 Cloud Scheduler 参考文档。
部署预定函数
在您部署预定函数时,系统会自动创建相关的调度器作业和 Pub/Sub 主题。Firebase CLI 会回显主题名称;您可以在 GCP 控制台中查看作业和主题。系统会根据以下惯例为主题命名:
firebase-scheduled-function_name-region
例如:
firebase-scheduled-scheduledFunctionCrontab-us-east1.