我正在编写一个Cloudflare Worker,需要在我的原始请求完成后ping一个分析服务。我不希望它阻止原始请求,因为我不希望延迟或分析系统的故障减慢或中断请求。如何创建在原始请求完成后开始和结束的请求?
addEventListener('fetch', event => {
event.respondWith(handle(event))
})
async function handle(event) {
const response = await fetch(event.request)
// Send async analytics request.
let promise = fetch("https://example.com")
.then(response => {
console.log("analytics sent!")
})
// If I uncomment this, only then do I see the
// "analytics sent!" log message. But I don't
// want to wait for it!
// await promise;
return response
}
答案 0 :(得分:5)
您需要使用Event.waitUntil()
来延长请求的持续时间。默认情况下,一旦发送最终响应,就会取消所有异步任务,但您可以使用waitUntil()
来延长请求处理生命周期以适应异步任务。 waitUntil()
的输入必须是Promise,它在任务完成时解析。
所以,而不是:
await promise
做的:
event.waitUntil(promise)