如何防止在node.js中两次调用相同URL的获取
Posted
技术标签:
【中文标题】如何防止在node.js中两次调用相同URL的获取【英文标题】:How to prevent fetch with same URL being called twice in node.js 【发布时间】:2018-05-01 10:48:10 【问题描述】:我要对后端进行 x 次调用。其中一些指向相同的 URL。我正在缓存结果。但我的问题是,如果我立即使用相同的 URL 调用 loadCached 两次(或多次),它实际上也会调用 fetch 两次,因为在第一次 fetch 解决之前缓存没有 url。因此,缓存仅在一次提取成功完成(=已解决)时才起作用。如何改进代码以等待解决第一次提取以避免重复查询?
function loadCached(url)
let cache = loadCached.cache || (loadCached.cache = new Map());
if (cache.has(url))
return Promise.resolve(cache.get(url)); // (*)
return fetch(url)
.then(response => response.text())
.then(text =>
cache[url] = text;
return text;
);
我正在使用 promise.all() 来等待 loadCached 解决。
【问题讨论】:
你需要缓存 promise 而不是结果。 runkit.com/moongod101/5a0f1c865f47c000128a96bb 我想会有什么效果? 【参考方案1】:你需要缓存整个 Promise:
function loadCached(url)
let cache = loadCached.cache || (loadCached.cache = new Map());
let promise;
if (cache.has(url))
promise = cache.get(url)
else
promise = fetch(url)
cache.set(url, promise)
return promise
.then(response => response.text())
还要注意,要使用map设置新值,需要使用set
方法,cache[url]
不正确。
【讨论】:
缓存fetch
的结果不太正确,因为一旦使用了该主体,您就不能再次使用它 - 假设 fetch 与浏览器中的 fetch 工作方式相同 - 所以,@ 987654325@ 只会工作一次 - 否定缓存的使用:p - 你可以 return promise.then(response => response.clone().text())
代替
非常感谢。我验证了这项工作,并且在 node.js 案例中也需要克隆。
@JaromandaX 您会将您的解决方案作为答案发布,以便 Petri kan 将其标记为解决方案吗?以上是关于如何防止在node.js中两次调用相同URL的获取的主要内容,如果未能解决你的问题,请参考以下文章
如何使用Backbone和Node.js / Hapi防止CORB错误?