我看到,如果一个请求没有响应,它将等待60秒以上。 就我而言,我嵌套了异步循环,并通过回调和Promise进行管理。每个元素都是一个api调用。 因此,我想检测例如api在10秒后是否没有响应。
我的api请求代码:
return new Promise((resolve, reject) => {
var start = moment();
const req = adapterFor(url).request(options, (resp) => {
//console.log(`El pr ${options.path}`);
let data = '';
resp.on('data', (chunk) => {
data += chunk;
});
resp.on('end', () => {
try {
tmpData = JSON.parse(data.trim());
if(tmpData.length != 0 && tmpData.films.length > 0) {
data = tmpData.films.filter(v => {
return v.film_o.length > 0
})
resolve(data);
}else resolve({"Errore" : url,error:some error',error_type:'some error',duration: ((moment() - start) / 1000)+' s'});
}catch (e) {
resolve({"Errore" : url,'error':'HERE MAYBE',error_type:'?!',duration: ((moment() - start) / 1000)+' s'});
}
// console.log(colors.gray("EL: " + tmpData.DS.Scheduling.Events.length.length));
});
});
req.end();
})
答案 0 :(得分:1)
如果可以使用ESnext,则可以使用Promise.race()。考虑以下示例:
Promise.race([
new Promise((resolve, reject) => setTimeout(() => resolve(1), 5000)),
new Promise((resolve, reject) => setTimeout(() => resolve(2), 10000))
]).then(res => console.log(res))
您可以在数组中提供多个Promise,Promise.race始终会选择最快的诺言并解决该诺言。因此,您可以将承诺作为一个要素,将超时作为第二个要素。然后,该承诺将始终在超时后或您的api调用完成后解决。首先解决的是任何问题。
https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Promise/race
答案 1 :(得分:1)
一个选项是指示一个标志,该标志在配置的时间之后被拒绝。在下面的示例中,您可以看到变量 reqHasFinished 在请求回调中已更改,因此如果其变量为false,则可以拒绝该请求:
return new Promise((resolve, reject) => {
let start = moment(),
reqHasFinished = false;
const req = adapterFor(url).request(options, (resp) => {
reqHasFinished = true;
let data = '';
// resp operations here
});
// if after 10 seconds the request has not finished, the promise is rejected.
setTimeout(() => {
if (!reqHasFinished) {
reject('Go ahead');
}
}, 10000)
req.end();
});