如何处理前端开发中的并发查询

背景

JS 代码的执行过程中,同一事件循环中可能存在多个同样的请求,这些请求得到的都是同样的结果。 通常我们可以通过 的机制来限制多个事件循环中的查询,但在同一个循环里,这些请求在没有得到返回结果之前,我们是没法加的,因为请求可能会失败。


如果请求量很大,那么就可能导致查询量过大,造成第三方(端、后台)承受一定的压力,影响性能。 这种情况类似于"缓存雪崩" 缓存雪崩是指在某一个时间段内,Cache缓存集中过期失效,如果这个时间段内有大量请求,那么所有的请求都会打到db数据库,导致数据库的访问量暴增,引起数据库崩溃

解决方案

这种情况的处理方法也很简单,需要用到缓存队列 ,在没有获取到查询结果前,我们将所有的请求回调函数都放进缓存队列 里,当唯一的请求得到结果后,再取出所有的回调函数进行执行,类似于Promisethen机制。

注意⚠️:这种方案仅适用于所查询的数据为静态数据,在短时间内多次查询的结果均相同的情况

ts 复制代码
let res // 响应结果
let lock = false // 请求锁
const queue = [] // 请求队列
const doReq = () => { // 请求方法
    console.log('正在请求...')
    return new Promise(resolve => {
        setTimeout(() => resolve(Math.random()), Math.random() * 3000) // 3s内响应
    })
}
// 请求缓存
function request(callback) {
    if (!res && !lock) {
        lock = true
        doReq().then((data) => {
            res = data
            let cb
            while(cb = queue.shift()) {
                cb(res)
            }
            lock = false
        })
    }
    if (res) {
        callback(res)
    } else {
        queue.push(callback)
    }
}

测试代码 & 打印结果

ts 复制代码
request(() => { console.log('查询1:', res) })
request(() => { console.log('查询2:', res) })
request(() => { console.log('查询3:', res) })

应用场景

相关推荐
小兵张健8 小时前
价值1000的 AI 工作流:Codex 通用前端协作模式
前端·aigc·ai编程
sunny_8 小时前
面试踩大坑!同一段 Node.js 代码,CJS 和 ESM 的执行顺序居然是反的?!99% 的人都答错了
前端·面试·node.js
拉不动的猪8 小时前
移动端调试工具VConsole初始化时的加载阻塞问题
前端·javascript·微信小程序
ayqy贾杰10 小时前
Agent First Engineering
前端·vue.js·面试
IT_陈寒10 小时前
SpringBoot实战:5个让你的API性能翻倍的隐藏技巧
前端·人工智能·后端
iceiceiceice11 小时前
iOS PDF阅读器段评实现:如何从 PDFSelection 精准还原一个自然段
前端·人工智能·ios
大金乄11 小时前
封装一个vue2的elementUI 表格组件(包含表格编辑以及多级表头)
前端·javascript
葡萄城技术团队12 小时前
【性能优化篇】面对万行数据也不卡顿?揭秘协同服务器的“片段机制 (Fragments)”
前端
程序员阿峰12 小时前
2026前端必备:TensorFlow.js,浏览器里的AI引擎,不写Python也能玩转智能
前端
Jans12 小时前
Shipfe — Rust 写的前端静态部署工具:一条命令上线 + 零停机 + 可回滚 + 自动清理
前端