发送请求的传送机制优化--浏览器细节深究(2)

背景

首先介绍一下我们项目的架构:

可以看到我们的平台分为四个部分:1. 监控中台 2. npm 包 3. 产生错误 & 性能信息的页面 4. 后端

更详细的介绍可以看这里--让我们一起写一个前端监控系统吧!(1)

首先我们需要知道,我们想要使用 npm 包,其实就是把 npm 包植入 "产生错误 & 性能信息的页面",那么我们传递信息的过程本身,就会给"产生错误 & 性能信息的页面"带来相当大的负担,那么我们需要去做一个优化,怎么去做呢?

操作思路

最开始我们使用的是轮询策略,那么这种行为必然带来问题------"持续不断的请求拖垮页面性能。"

然后我们就开始了优化的思路,第一个方面是优化轮询,轮询本身的逻辑在于产生一个请求就往后端发送,而我们优化的思路在于合并这些发送的请求。

这里使用的东西主要有两个------------localStorage + 队列。

我们这里有两个核心的判断逻辑,第一个核心逻辑:当队列的长度 >= 20 的时候,我们就把队列清空,也就是把我们的值传递到后端去;第二个核心逻辑:每过一秒钟,如果队列不为空,我们进行一次倾倒,也就是把队列中的值发送到后端去。

那么这里还有一些考量:

  1. 为什么不用 SessionStorage?
  • 因为我们需要跨页面通信,SessionStorage 无法满足。
  1. 为什么不用 indexDB
  • 首先是 indexDB 的写法过于复杂了,而它带来的好处是什么呢?主要是容量很大很大。但是我们需要这么大的容量吗?显然不需要,因为我们队列在超过 20 个之后会进行清空操作,所以没有必要花时间精力去写 indexDB。
  • 另一方面 localStorage 的 5MB 已经够用了。
  • cookie 4kb 的容量就更不用说了。

但是这里仍然存在一个问题,那就是 1s 中间也可能无法传递信息。

举个例子,用户在某个一秒的中间关闭了浏览器,导致存在队列里的信息无法发送给后端,我们这时候该怎么处理?

那么我们这个时候就要拿出之前用的一个 API------Navigator.sendBeacon,它可以在浏览器卸载的时候发送请求给后端,从而把没来得及发出去的数据传给后端。

下篇文章会仔细的介绍一下这个"浏览器卸载"到底是啥时候~

结语

那么这就是本篇文章的所有内容啦,可以留个赞再走莫~

相关推荐
二十一_16 分钟前
炸了!Claude Code 51万行源码全部泄露,我已经拿到了完整代码
前端·langchain·claude
RePeaT21 分钟前
npm 依赖版本号中 `^` 和 `~` 到底有什么区别?
前端·javascript·npm
DanCheOo23 分钟前
多模型适配:一套代码接 6 家 AI 厂商
前端·ai编程
米丘24 分钟前
Node.js 事件循环
前端·javascript·node.js
Forever7_25 分钟前
紧急!Axios 被投毒,3亿项目受到影响!教你怎么自查!
前端·axios
zzialx12325 分钟前
HarmonyOS:照片添加多样式的水印信息
前端
前端冒菜师30 分钟前
记一次AI全栈开发的过程
前端·ai编程
Giant10037 分钟前
深度玩转 Cursor Rules:让 AI 生成的代码 100% 符合团队规范
前端·面试
代码煮茶40 分钟前
Vue3 组件通信实战 | 8 种组件通信方式全解析
前端·vue.js
kyriewen40 分钟前
自定义事件:让代码之间也能“悄悄对话”
前端·javascript·面试