前端监控:让你的网站问题无处遁形

前端监控:让你的网站问题无处遁形

毒舌时刻

前端监控?这不是后端的事吗?

"我的代码没问题,不需要监控"——结果用户反馈网站崩溃,自己却一无所知,
"我有日志,还需要什么监控"——结果日志太多,根本找不到问题,
"监控太复杂了,我没时间做"——结果问题频发,用户流失。

醒醒吧,前端监控是前端开发的重要组成部分,不是可有可无的!

为什么你需要这个?

  • 问题发现:及时发现和定位前端问题
  • 性能优化:了解网站性能瓶颈
  • 用户体验:了解用户真实使用情况
  • 数据驱动:基于数据做出决策

反面教材

// 反面教材:没有任何监控 function App() { return ( <div> <h1>我的网站</h1> {/* 没有任何错误处理和监控 */} <button onClick={() => { // 可能会出错的代码 const data = fetchData(); processData(data); }}>点击我</button> </div> ); } // 反面教材:简单的console.log function fetchData() { try { const data = // 从API获取数据 return data; } catch (error) { console.log('Error:', error); // 只在控制台打印,没有持久化 return null; } } 

正确的做法

// 正确的做法:使用专业的监控工具 // 安装依赖:npm install @sentry/react @sentry/tracing // index.js import React from 'react'; import ReactDOM from 'react-dom/client'; import App from './App'; import * as Sentry from '@sentry/react'; import { BrowserTracing } from '@sentry/tracing'; // 初始化Sentry Sentry.init({ dsn: 'YOUR_SENTRY_DSN', integrations: [new BrowserTracing()], tracesSampleRate: 1.0, // 环境信息 environment: process.env.NODE_ENV, // 发布版本 release: '[email protected]' }); ReactDOM.createRoot(document.getElementById('root')).render( <React.StrictMode> <App /> </React.StrictMode> ); // 正确的做法:错误边界 import React from 'react'; import * as Sentry from '@sentry/react'; class ErrorBoundary extends React.Component { constructor(props) { super(props); this.state = { hasError: false }; } static getDerivedStateFromError(error) { // 更新状态,下次渲染时显示降级UI return { hasError: true }; } componentDidCatch(error, errorInfo) { // 捕获错误并发送到Sentry Sentry.captureException(error, { extra: errorInfo }); } render() { if (this.state.hasError) { // 降级UI return <h1>Something went wrong.</h1>; } return this.props.children; } } // 正确的做法:性能监控 import { usePerformanceObserver } from 'web-vitals'; function PerformanceMonitor() { usePerformanceObserver(({ entries }) => { entries.forEach((entry) => { // 发送性能数据到监控服务 if (entry.name === 'first-contentful-paint') { Sentry.captureMessage('FCP', { level: 'info', extra: { value: entry.startTime } }); } if (entry.name === 'largest-contentful-paint') { Sentry.captureMessage('LCP', { level: 'info', extra: { value: entry.startTime } }); } }); }); return null; } // 正确的做法:用户行为监控 function trackUserAction(action, data) { // 发送用户行为数据到监控服务 Sentry.captureMessage(action, { level: 'info', extra: data }); } // 正确的做法:网络请求监控 function fetchWithMonitoring(url, options = {}) { const start = performance.now(); return fetch(url, options) .then(response => { const end = performance.now(); const duration = end - start; // 发送网络请求数据到监控服务 Sentry.captureMessage('Network Request', { level: 'info', extra: { url, status: response.status, duration } }); return response; }) .catch(error => { // 捕获网络请求错误 Sentry.captureException(error, { extra: { url } }); throw error; }); } // 正确的做法:在组件中使用 function App() { return ( <ErrorBoundary> <PerformanceMonitor /> <div> <h1>我的网站</h1> <button onClick={() => { trackUserAction('Button Click', { button: 'submit' }); fetchWithMonitoring('https://api.example.com/data') .then(res => res.json()) .then(data => processData(data)) .catch(error => { console.error('Error:', error); }); }} > 点击我 </button> </div> </ErrorBoundary> ); } 

毒舌点评

看看,这才叫前端监控!不是简单地console.log,而是使用专业的监控工具,从错误监控、性能监控、用户行为监控等多个方面入手。

记住,前端监控不是为了发现错误,而是为了预防错误。通过监控数据,你可以了解用户的真实使用情况,发现潜在的问题,从而不断优化你的网站。

所以,别再觉得监控不重要了,它是你网站质量的保障!

总结

  • 错误监控:使用Sentry等工具捕获和分析错误
  • 性能监控:监控Core Web Vitals等性能指标
  • 用户行为:跟踪用户点击、页面浏览等行为
  • 网络监控:监控API请求的响应时间和成功率
  • 错误边界:使用React错误边界捕获组件错误
  • 日志聚合:集中管理和分析日志
  • 告警机制:设置阈值,当出现问题时及时告警
  • 数据可视化:通过图表直观展示监控数据

前端监控,让你的网站问题无处遁形!

Read more

【前端部署在云服务器如何与本地联调--Frp内网穿透】

【前端部署在云服务器如何与本地联调--Frp内网穿透】

苍穹外卖前端部署在云服务器如何与本地联调--Frp内网穿透 * 1. 前言 * 2. FRP是什么 * 3. 解决步骤 * 3.1 在云服务器安装服务端frps,然后开启开机自启(**参考第4部分**) * 3.2 在本地电脑安装客户端fprc(**参考第4部分**) * 4. Frp(C/S)0.64.0各个系统的安装方法 * 4.1 frps安装(Linux)服务端 * 4.2 frpc安装(windows)客户端 * 4.3 frpc安装(==mac==)客户端 * 4.4 frpc安装(Linux)客户端 1. 前言 写这片文章的目的是为了解决上篇苍穹外卖项目的前端部署到云服务器的遗留问题:前端的云服务器的IP是公网IP,而我本地调试的Java后端是内网,前端响应的地址找不到本地的服务器。那么如何让云服务器上的前端项目能够找到后端的对应的地址呢?

从前端视角看鸿蒙PC开发:遇到的问题与实践

鸿蒙PC发布至今已过去6个多月。就在这个月,我终于也是通过华为得到了一台鸿蒙PC 😋 拿到的一瞬间真的很激动,它真的是太薄了,又薄又轻,比我现在用的 Macbook Air (M1) 还要薄要轻一半,属实是惊艳到我了。和我的 Macbook Air 一样也是无风扇的设计,目前不知道它的散热性能如何,但目前使用起来,发热量并不大,而且非常的安静。 拿到快递我迫不及待立刻开箱,开机,初始化配置之后,马上各个APP都看了几遍,整个系统特别的流畅丝滑,真的爽 😊 鸿蒙PC的桌面,整体风格上像是 MacOS + Windows 的结合体,将类 Windows 的开始菜单放在了左下角,将类似 MacOS 启动台放在了中间,其中中间的头四个图标(启动台、多桌面、文件管理、回收站)是无法被移除的,而其他的图标则可以按照个人需要添加和移除。 看了一下应用市场,现在鸿蒙PC的生态还是比较封闭式的,和苹果一样,甚至在应用商店的审核机制上比苹果还要更加严格。电脑一拿到,内置安装了一堆APP,

‌Web API测试工具与技巧

‌Web API测试工具与技巧

一、核心工具演进:2025–2026年主流平台能力升级‌ 2025年以来,API测试工具已从“调试器”全面进化为“全生命周期协作平台”。以下为当前行业主流工具的核心能力跃迁: 工具2025–2026年关键升级对测试工程师的价值‌Postman‌集成AI辅助测试生成器,支持自然语言描述自动生成测试用例与断言;支持动态环境变量预测与异常响应模式学习减少70%以上手动用例编写时间,提升回归测试覆盖率‌Apifox‌原生支持GraphQL测试用例管理,单接口可创建多组Query/Variables组合;内置Mock服务与自动化测试引擎一体化实现“设计-调试-测试-Mock”闭环,无需切换工具‌Swagger UI 5+‌支持OpenAPI 3.1的$dynamicRef与unevaluatedProperties,可实时验证复杂嵌套Schema;新增Webhooks交互调试面板确保API契约与实现一致,降低集成阶段返工率‌JMeter‌新增HTTP/3与gRPC协议支持;集成Prometheus监控插件,实时输出TPS、P99响应时间满足云原生架构下高性能API压测需求‌Karate‌

三种适用于Web版IM(即时通讯)聊天信息的加密算法实现方案

三种适用于Web版IM(即时通讯)聊天信息的加密算法实现方案

文章目录 * **第一部分:引言与核心密码学概念** * **1.1 为什么IM需要端到端加密(E2EE)?** * **1.2 核心密码学概念与工具** * **第二部分:方案一:静态非对称加密(基础方案)** * **2.1 方案概述与流程** * **2.2 前端Vue实现(使用node-forge)** * **1. 安装依赖** * **2. 核心工具类 `crypto.js`** * **3. Vue组件中使用** * **2.3 后端Java实现(Spring Boot)** * **1. 实体类** * **2. Controller层** * **3. WebSocket配置** * **2.4 密钥管理、注册与登录集成** * **1. 用户注册/登录时生成密钥** * **2. 密钥设置页面** * **2.