[小结]-线上Bug监控

为什么需要监控

你进入了一家公司,开发了一个电商平台。

随着公司越做越大,用户越来越多,用户遇到bug投诉的也越来越多。

但是愿意bug上报的是少数,大部分遇到bug都懒得报,当有人打电话给你们投诉时,意味着更多人已经碰到过这个bug。

你想解决这些bug,但是你又没办法知道用户咋操作的。你自己操作又操作不出来

你就想啊,如果我能有办法还原用户当时是怎么操作的就就好了

JS回放技术

js回放技术就是把用户的操作路径展示出来。我们可以像看视频一样,回放用户的操作路径

这里我们借用到一个核心的第三方库--rrweb

Bug监控系统

系统设计

bug上报

  1. 核心库
  1. 记录用户操作: 程序初始化完成后开始录制(监控页面变化和用户事件触发), 然后记录数据到数组
  1. 触发日志上报: 当用户操作异常(JS报错)或者请求异常(axios报错), 把错误信息和用户操作进行上报

bug回放

  1. 页面结构:
  1. 核心库
  1. 核心逻辑

先获取日志列表, 点击回放按钮后, 执行具体的回放

日志服务

  1. 提供接口 (日志列表/日志详情/日志上报)
  1. 数据结构

events: 记录用用户操作

error: 记录具体错误信息

type: 3 (鼠标移动) positions: 移动位置

简单原理

原理核心思想很简单,把页面上状态都变成json数据,然后拿着这个json数据再去转化为页面

体系完善

rrweb的问题在于我们只是记录了用户的界面操作,我们无法监控到具体出了啥问题,因为他无法录制js里的代码。

我们还要建立起一个日志上报体系。用来记录用户的操作路径。

示例:

2025-12-12 12:00:00 张三登录

2025-12-12 12:01:00 张三访问购物车

2025-12-12 12:03:00 张三支付

2025-12-12 12:04:00 张三支付失败, 失败原因: xxxx

线上监控体系

用户回放+操作日志就可以组成一个比较完整的线上监控体系, 帮助程序员快速定位问题

  1. 操作日志可以快速查看用户的关键操作, 定位问题范围和bug优先级
  2. 用户操作回放和报错信息可以具体的查看问题, 定位问题原因
相关推荐
lpd_lt9 分钟前
服务端类vue等页面AI测试方向
前端·vue.js·人工智能
AugustRed12 分钟前
A2UI 完整学习指南(含 Java 后端 + 前端实战示例)
java·开发语言·前端
王莎莎-MinerU15 分钟前
Agent 时代,科学数据 API 需要重新设计
大数据·前端·数据库·人工智能·个人开发
jingling55519 分钟前
自建技术博客实战(三):工具专栏——地图定位、声音复刻与 rembg 抠图
android·开发语言·前端·ai·nextjs
小小小小宇28 分钟前
Chrome 插件在新开页生效
前端
橘子味的冰淇淋~29 分钟前
优化前端性能之从“全局引入”改为“按需引入”
前端·javascript·vue.js
沐灵洛35 分钟前
构建 Mac App Store 应用须知(全)
前端
KaMeidebaby36 分钟前
卡梅德生物技术快报|蛋白修饰调控 NETosis 分子机制及实验研究进展
前端·数据库·人工智能·算法·百度
颜进强41 分钟前
Claude Code -16 文件引用与加载机制完整实践:从 CLAUDE.md 到 Skills 与 Subagents
前端·后端·ai编程
2501_9400417441 分钟前
硬核全栈开发命题,覆盖高并发/实时/微服务
前端