Sentry 官方 JavaScript SDK 简介与调试指南
系列
- 1 分钟快速使用 Docker 上手最新版 Sentry-CLI - 创建版本
- 快速使用 Docker 上手 Sentry-CLI - 30 秒上手 Source Maps
- Sentry For React 完整接入详解
- Sentry For Vue 完整接入详解
- Sentry-CLI 使用详解
- Sentry Web 性能监控 - Web Vitals
- Sentry Web 性能监控 - Metrics
- Sentry Web 性能监控 - Trends
- Sentry Web 前端监控 - 最佳实践(官方教程)
- Sentry 后端监控 - 最佳实践(官方教程)
- Sentry 监控 - Discover 大数据查询分析引擎
- Sentry 监控 - Dashboards 数据可视化大屏
- Sentry 监控 - Environments 区分不同部署环境的事件数据
- Sentry 监控 - Security Policy 安全策略报告
- Sentry 监控 - Search 搜索查询实战
- Sentry 监控 - Alerts 告警
- Sentry 监控 - Distributed Tracing 分布式跟踪
- Sentry 监控 - 面向全栈开发人员的分布式跟踪 101 系列教程(一)
- Sentry 监控 - Snuba 数据中台架构简介(Kafka+Clickhouse)
- Sentry 监控 - Snuba 数据中台架构(Data Model 简介)
- Sentry 监控 - Snuba 数据中台架构(Query Processing 简介)
源码仓库地址
https://github.com/getsentry/sentry-javascript
支持的平台
对于每个主要的 JavaScript
平台,都有一个特定的高阶 SDK
,可以在单个包中提供您需要的所有工具。 有关更多详细信息,请参阅这些 SDK 的 README 和说明:
@sentry/browser
: 浏览器的SDK
,包括对基础主干(GlobalHandlers
,TryCatch
,Breadcrumbs
,LinkedErrors
,UserAgent
,Dedupe
)的集成。@sentry/node
: 适用于Node
的SDK
,包括Express
、Koa
、Loopback
、Sails
和Connect
的集成。@sentry/angular
: 启用Angular
集成的浏览器SDK
。@sentry/react
: 启用React
集成的浏览器SDK
。@sentry/ember
: 启用Ember
集成的浏览器SDK
。@sentry/vue
: 启用Vue
集成的浏览器SDK
。@sentry/gatsby
:Gatsby
的SDK
。@sentry/nextjs
:Next.js
的SDK
。@sentry/integrations
: 可用于增强JS SDK
的可插拔集成。@sentry/electron
: 支持原生崩溃的Electron SDK
。@sentry/react-native
: 支持原生崩溃的React Native SDK
。@sentry/capacitor
: 支持原生崩溃的Capacitor App
和Ionic
的SDK
。sentry-cordova
: 支持原生崩溃的Cordova App
的SDK
。raven-js
: 旧的稳定JavaScript SDK
,我们仍然支持并发布SDK
的错误修复,但所有新功能都将在@sentry/browser
中实现,它是继任者。raven
:旧的稳定Node SDK
,与raven-js
一样,我们仍然支持并发布SDK
的错误修复,但所有新功能都将在@sentry/node
中实现,它是继任者。
用于平台 SDK
开发的共享软件包
@sentry/tracing
: 为性能监控
/跟踪
提供集成
和扩展
。@sentry/hub
:SDK
的全局状态管理。@sentry/minimal
:Sentry
支持的最小SDK
@sentry/core
: 具有接口
、类型定义
和基
类的所有JavaScript SDK
的基础。@sentry/utils
: 一组对各种SDK
有用的辅助程序和实用函数。@sentry/types
: 所有软件包中使用的类型定义。
开发调试
设置环境
要运行 test suite
和 code linter
,需要 node.js
和 yarn
。
sentry-javascript
是一个包含多个软件包的 monorepo
,使用 lerna
管理它们。 首先,安装所有依赖项,使用 lerna
引导工作区,然后执行初始构建,以便 TypeScript
可以读取所有链接的类型定义。
yarn
yarn lerna bootstrap
yarn build
这样,repo
就完全设置好了,您可以运行所有命令了。
构建软件包
由于我们使用的是 TypeScript
,因此您需要将代码转换为 JavaScript
才能使用它。来自 repo
的顶层,有三个可用命令:
yarn build:dev
,它运行每个包的ES5
和ES6
版本的一次性构建。yarn build:dev:filter <name of npm package>
,它只在与给定包相关的项目中运行yarn build:dev
(例如,运行yarn build:dev:filter @sentry/react
将构建react
包、它的所有依赖项(utils
、core
、browser
等),以及所有依赖它的包(目前是gatsby
和nextjs
))。yarn build:dev:watch
,在watch
模式下运行yarn build:dev
(推荐)
添加测试
任何重要的修复
/功能
都应该包括测试。您会在每个软件包中找到一个 test
文件夹。
请注意,仅对于 browser
包,如果您将新文件添加到集成测试套件中,您还需要将其添加到shell.js
中的列表中。 在所有包中,向现有文件添加测试都可以开箱即用。
运行测试
运行测试与构建的工作方式相同 - 在项目根目录运行 yarn test
将对所有包运行测试,在特定包中运行 yarn test
将为该包运行测试。还有一些命令可以在每个位置运行测试的子集。查看相应 package.json
的 scripts
条目以了解详细信息。
注意:你必须在 yarn test
工作之前运行 yarn build
。
调试测试
如果您在编写测试时遇到麻烦并需要调试其中之一,您可以使用 VSCode
的 debugger
来完成。
如果您尚未安装它,请安装 Tasks Shell Input
扩展,您可以在侧边栏的“扩展”
选项卡中找到它作为推荐的工作区扩展之一。
- 将断点或
debugger
语句放置在测试或底层代码中您希望jest
暂停的任何位置。 - 打开包含相关测试的文件,并确保其选项卡处于活动状态(以便您可以看到文件的内容)。
- 切换到侧边栏中的
debugger
,然后从下拉列表中选择Debug unit tests - just open file
。 - 单击绿色的
“play”
按钮以watch
模式在打开的文件中运行测试。
实战
测试代码:
- https://github.com/getsentry/sentry-javascript/blob/master/packages/minimal/test/lib/minimal.test.ts
专业提示:如果您的任何断点在由多个测试运行的代码中,并且您运行整个测试文件,您将在不关心的测试中间一遍又一遍地停留在这些断点上。为避免这种情况,请将测试的初始 it
或 test
替换为 it.only
或 test.only
。这样,当您遇到断点时,您就会知道您到达了有问题的测试的一部分。
Linting
与构建和测试类似,linting
可以通过调用 yarn lint
在项目根目录或单个包中完成。
注意:你必须在 yarn lint
工作之前运行 yarn build
。
公众号:黑客下午茶
Sentry 官方 JavaScript SDK 简介与调试指南的更多相关文章
- Sentry(v20.12.1) K8S 云原生架构探索,SENTRY FOR JAVASCRIPT SDK 配置详解
系列 Sentry-Go SDK 中文实践指南 一起来刷 Sentry For Go 官方文档之 Enriching Events Snuba:Sentry 新的搜索基础设施(基于 ClickHous ...
- Sentry(v20.12.1) K8S 云原生架构探索,SENTRY FOR JAVASCRIPT Source Maps 详解
系列 Sentry-Go SDK 中文实践指南 一起来刷 Sentry For Go 官方文档之 Enriching Events Snuba:Sentry 新的搜索基础设施(基于 ClickHous ...
- Sentry(v20.12.1) K8S 云原生架构探索,SENTRY FOR JAVASCRIPT 故障排除
系列 Sentry-Go SDK 中文实践指南 一起来刷 Sentry For Go 官方文档之 Enriching Events Snuba:Sentry 新的搜索基础设施(基于 ClickHous ...
- Sentry(v20.12.1) K8S 云原生架构探索, SENTRY FOR JAVASCRIPT 手动捕获事件基本用法
系列 Sentry-Go SDK 中文实践指南 一起来刷 Sentry For Go 官方文档之 Enriching Events Snuba:Sentry 新的搜索基础设施(基于 ClickHous ...
- NodeJS & Dapr Javascript SDK 官方使用指南
Dapr 是一个可移植的.事件驱动的运行时,它使任何开发人员能够轻松构建出弹性的.无状态和有状态的应用程序,并可运行在云平台或边缘计算中,它同时也支持多种编程语言和开发框架.Dapr 确保开发人员专注 ...
- linux内核调试指南
linux内核调试指南 一些前言 作者前言 知识从哪里来 为什么撰写本文档 为什么需要汇编级调试 ***第一部分:基础知识*** 总纲:内核世界的陷阱 源码阅读的陷阱 代码调试的陷阱 原理理解的陷阱 ...
- Linux Kernel - Debug Guide (Linux内核调试指南 )
http://blog.csdn.net/blizmax6/article/details/6747601 linux内核调试指南 一些前言 作者前言 知识从哪里来 为什么撰写本文档 为什么需要汇编级 ...
- 华为云函数中使用云数据库的JavaScript SDK基础入门
背景介绍 使用云数据库Server端的SDK,此处我以华为提供的官方Demo为例,他们的Demo也已经开源放在了GitHub上,大家需要的可以自行下载. https://github.com/AppG ...
- Hello.js – Web 服务授权的 JavaScript SDK
Hello.js 是一个客户端的 Javascript SDK,用于实现 OAuth2 认证(或者基于 OAuth 代理实现的 OAuth1)的 Web 服务和查询 REST API. HelloJS ...
随机推荐
- node.js及npm安装&配置
之前我们在文言文安装教程里写过node.js及npm的安装,这里我们详细写一下. 下载node.js node.js下载分为两种,官网nodejs.org,和国内官网nodejs.cn,国内的童鞋建议 ...
- MySQL8.0.20安装教程图文详解,MySQL8.0.20安装教程winodws10
MySQL8.0.20安装教程图文详解,非常详细 一:mysql官网下载 https://dev.mysql.com/downloads/file/?id=494993 不用注册,直接下载就好 二:解 ...
- Serverless 如何在阿里巴巴实现规模化落地?
作者 | 赵庆杰(卢令) 来源 | Serverless 公众号 一.Serverless 规模化落地集团的成果 2020 年,我们在 Serverless 底层基建上做了非常大的升级,比如计算升级到 ...
- js 面向对象 动态添加标签
有点逻辑 上代码 thml布局 点击查看代码 <!DOCTYPE html> <html lang="en"> <head> <meta ...
- 开源协同OA办公平台教程:O2OA服务管理中,接口的调用权限
本文介绍O2OA服务管理中,接口的权限设定和调用方式. 适用版本:5.4及以上版本 创建接口 具有服务管理设计权限的用户(具有ServiceManager角色或Manager角色)打开" ...
- 轻量级 Java 基础开发框架,Solon & Solon Cloud 1.5.48 发布
Solon 已有120个生态扩展插件,此次更新主要为细节打磨: 增加 solon.serialization,做为序列化的基础插件 优化 所有Json序列化插件,使之可方便定制类型序列化 public ...
- 4.19——数组双指针——26. 删除有序数组中的重复项 & 27. 删除有序数组中的重复项II & 80. 删除有序数组中的重复项 II
第一次做到数组双指针的题目是80: 因为python的List是可以用以下代码来删除元素的: del List[index] 所以当时的我直接用了暴力删除第三个重复元素的做法,大概代码如下: n = ...
- (课内)信安数基RSA-基础&&解密加速
RSA基本实现 首先获得N比特的伪随机数:使用Random库中内容. randint(n,m) 表示生成一个在n和m之间的随机数, **表示乘幂. getPrime找素数,or 1运算是一种优化:如果 ...
- CanalAdmin搭建Canal Server集群
CanalAdmin搭建Canal Server集群 一.背景 二.机器情况 三.实现步骤 1.下载canal admin 2.配置canalAdmin 3.初始化canal admin数据库 4.启 ...
- 转:进行vivado开发时,Generate Bitstream报错[DRC NSTD-1],详细解决步骤
报错如下 [Drc 23-20] Rule violation (NSTD-1) Unspecified I/O Standard - 4 out of 142 logical ports use I ...