如何使用Cloudflare Worker创建异步请求(非阻塞)

时间:2018-03-14 20:21:28

标签: javascript cloudflare-workers

我正在编写一个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
}

1 个答案:

答案 0 :(得分:5)

您需要使用Event.waitUntil()来延长请求的持续时间。默认情况下,一旦发送最终响应,就会取消所有异步任务,但您可以使用waitUntil()来延长请求处理生命周期以适应异步任务。 waitUntil()的输入必须是Promise,它在任务完成时解析。

所以,而不是:

await promise

做的:

event.waitUntil(promise)

Here's the full working script in the Playground.