node.js - 如何使用数千个 Promise 等待多个函数 Firebase Functions
问题描述
我每晚都使用以下代码删除所有旧数据。
每个功能都可以正常工作,如果我创建多个计划任务,每个功能一个,它也可以正常工作。但是,当我将它们组合成一个名为 scheduleCleanData 的计划任务时,我收到错误:无法加载默认凭据。浏览到https://cloud.google.com/docs/authentication/getting-started了解更多信息。在 GoogleAuth.getApplicationDefaultAsync (/workspace/node_modules/google-auth-library/build/src/auth/googleauth.js:161:19) 在 process._tickCallback (internal/process/next_tick.js:68:7)
根据这篇文章,我相信这是由于函数没有等待回调,而不是凭证问题。但是,添加async或await关键字会导致解析错误。其中一些集合需要删除数千条记录。
任何帮助如何修改此代码以正确等待将不胜感激!
const functions = require('firebase-functions');
const admin = require('firebase-admin');
const client = require('firebase-tools');
admin.initializeApp(functions.config().firebase)
const db = admin.firestore();
const runtimeOpts = {
timeoutSeconds: 300,
memory: '1GB'
}
exports.scheduledCleanData = functions
.runWith(runtimeOpts)
.pubsub.schedule('0 3 * * *')
.timeZone('America/Chicago')
.onRun((context) => {
return cleanOldAssignments()
.then(cleanOldDuties())
.then(cleanOldEvents())
.then(console.info("scheduledCleanData Complete!"));
});
function cleanOldAssignments() {
const dateYesterday = new Date(new Date().getTime() - (24 * 60 * 60 * 1000)); // 24 hours
return db.collectionGroup('assignments').where('date', '<', dateYesterday).get()
.then(querySnapshot => {
console.info("Old assignments to remove: " + querySnapshot.size);
const promises = [];
querySnapshot.forEach(doc => {
promises.push(doc.ref.delete());
});
return Promise.all(promises);
});
}
function cleanOldDuties() {
const dateYesterday = new Date(new Date().getTime() - (24 * 60 * 60 * 1000)); // 24 hours
return db.collectionGroup('duties').where('date', '<', dateYesterday).get()
.then(querySnapshot => {
console.info("Old duties to remove: " + querySnapshot.size);
const promises = [];
querySnapshot.forEach(doc => {
promises.push(doc.ref.delete());
});
return Promise.all(promises);
});
}
function cleanOldEvents() {
const dateYesterday = new Date(new Date().getTime() - (24 * 60 * 60 * 1000)); // 24 hours
return db.collectionGroup('events').where('date', '<', dateYesterday).get()
.then(querySnapshot => {
console.info("Old events to remove: " + querySnapshot.size);
const promises = [];
querySnapshot.forEach(doc => {
promises.push(doc.ref.delete());
});
return Promise.all(promises);
});
}
解决方案
如果cleanOldDuties
两者cleanOldEvents
都返回更多承诺,则您的代码没有考虑到它们。您将需要显式返回它们的值以沿承诺链传播:
return cleanOldAssignments()
.then(() => { return cleanOldDuties() })
.then(() => { return cleanOldEvents() })
在没有看到这些其他函数的确切代码的情况下,不确定这是否会起作用。这些功能也必须正确实现。
async/await 几乎总是一种更清晰的方式来表达这些事情。您可能也只是错误地使用了它们。
推荐阅读
- python - 在 many=True 序列化程序视图集上获取经过身份验证的用户
- java - 程序找到两个字符对但不是第三个
- python - 如何〜打印('你失败')〜正确的密码猜测代码。我卡住了
- python - VS Code Jupyter Notebooks - 如何停止结果文本换行?
- python - 如何连接两个数据框,一个带有日期时间索引,另一个带有普通索引
- java - 如何让 r.KeyPress 识别双字母?
- python - 如何使用 numpy 创建一个非重复随机数矩阵,同时在这些随机数之间有一个范围?
- c++ - 尝试使用 OpenGL 设置 Xcode
- python - 将两列合并为一列,同时尊重升序
- google-sheets - 用于 maxifs 的 Google 表格数组公式