Expo大作战(十七)--expo结合哨兵(sentry)进行错误异常记录
简要:本系列文章讲会对expo进行全面的介绍,本人从2017年6月份接触expo以来,对expo的研究断断续续,一路走来将近10个月,废话不多说,接下来你看到内容,讲全部来与官网
我猜去全部机翻+个人修改补充+demo测试的形式,对expo进行一次大补血!欢迎加入expo兴趣学习交流群:597732981
【之前我写过一些列关于expo和rn入门配置的东i西,大家可以点击这里查看:从零学习rn开发】
相关文章:
Expo大作战(一)--什么是expo,如何安装expo clinet和xde,xde如何使用
Expo大作战(二)--expo的生命周期,expo社区交流方式,expo学习必备资源,开发使用expo时关注的一些问题
Expo大作战(三)--针对已经开发过react native项目开发人员有针对性的介绍了expo,expo的局限性,开发时项目选型注意点等
Expo大作战(四)--快速用expo构建一个app,expo中的关键术语
Expo大作战(五)--expo中app.json 文件的配置信息
Expo大作战(六)--expo开发模式,expo中exp命令行工具,expo中如何查看日志log,expo中的调试方式
Expo大作战(七)--expo如何使用Genymotion模拟器
Expo大作战(八)--expo中的publish以及expo中的link,对link这块东西没有详细看,大家可以来和我交流
接下来就开始撸码
使用哨兵(Sentry)
Sentry是一个崩溃报告和聚合平台,可为您提供“实时洞察生产部署信息以重现和解决崩溃问题”。
它会通知您用户在使用应用程序时遇到的例外情况,并组织您从他们的Web仪表板进行分类。自动报告的异常包括源映射堆栈跟踪和其他相关上下文(设备ID,平台,Expo verison等);您还可以提供特定于您的应用程序的其他上下文,如当前的路由和用户标识。
为什么Sentry?
Sentry对待React Native是一流的公民,我们与Sentry合作确保expo也是如此。这很容易设置和使用。
它的规模可以满足甚至最大的项目的需求。
它适用于大多数平台,因此您可以使用相同的服务来报告您的服务器,CLI或桌面应用程序错误,就像您用于Expo应用程序一样。
我们相信它为我们在expo的项目。
每个月最多可以有10,000个活动免费。
将Sentry添加到您的exoi项目中
注册一个Sentry帐户并创建一个项目
一旦你注册,你将被提示创建一个项目。输入您的项目名称并继续。
现在系统会提示您配置您的应用程序,单击“获取您的DSN”链接并复制您的“公共DSN”,您很快就会需要它。
转到Sentry API部分并创建一个授权令牌。您可以使用默认配置,该令牌将永远不会提供给您的应用的用户。复制您的授权令牌并保存以备后用。
转到您的项目仪表板,转到sentry.io并点击屏幕顶部的“选择项目”,然后选择您的项目。这是您将在后面看到异常情况的地方。现在,点击右上角的“项目设置”,然后复制项目“短名称”。然后点击左上角的图标以显示您帐户中的组织。点击设置齿轮图标并复制组织短名称。你将需要这个信息为你的app.json设置。
安装并配置Sentry
确保您使用支持异步/等待的Node的新版本(Node7.6+)
在你的项目中,安装expo整合:
npm i sentry-expo --save
在您的应用的主文件中添加以下内容(默认为App.js)。
import Sentry from 'sentry-expo'; // Remove this once Sentry is correctly setup.
Sentry.enableInExpoDevelopment = true; Sentry.config('your Public DSN goes here').install();打开app.json并添加一个postPublish钩子:
{
"expo": {
// ... your existing configuration "hooks": {
"postPublish": [
{
"file": "sentry-expo/upload-sourcemaps",
"config": {
"organization": "your organization's short name here",
"project": "your project short name here",
"authToken": "your auth token here"
}
}
]
}
}用源地图发布您的应用程序(Publish your app with sourcemaps)
使用postPublish挂钩后,现在您只需点击发布即可自动上传源地图。根据您在app.json中指定的版本和我们后端的发布ID,我们会在您每次点击发布时自动为Sentry分配一个独特发布版本 - 这意味着如果您忘记更新版本但点击发布,您仍然会获得独特的Sentry版本。如果你不熟悉在expo上发布,你可以在这里阅读更多。
报告语义错误
为了确保可靠地报告错误,Sentry推迟将数据报告给它们的后端,直到下次您在致命错误后加载应用程序,而不是在捕获异常时报告它为止。它将堆栈跟踪和其他元数据保存到AsyncStorage,并在应用程序启动时立即发送。
在dev中默认禁用
除非在调用
Sentry.config({...}).install()
之前设置了Sentry.enableInExpoDevelopment = true
,否则所有开发/本地错误都将被忽略,只有应用程序版本会向Sentry报告错误。你可以调用像entry.captureException(new Error('Oops!'))
这样的方法,但是这些方法将是no-op。了解更多关于哨兵
Sentry不仅仅是捕捉致命错误,更多地了解如何使用Sentry。
下一张继续介绍,这一篇主要介绍了:expo结合哨兵(sentry)进行错误异常记录, 欢迎大家关注我的微信公众号,这篇文章是否被大家认可,我的衡量标准就是公众号粉丝增长人数。欢迎大家转载,但必须保留本人博客链接!
Expo大作战(十七)--expo结合哨兵(sentry)进行错误异常记录的更多相关文章
- Expo大作战(十)--expo中的App Icon,expo中的Assets,expo中的ErrorHandling错误处理
简要:本系列文章讲会对expo进行全面的介绍,本人从2017年6月份接触expo以来,对expo的研究断断续续,一路走来将近10个月,废话不多说,接下来你看到内容,讲全部来与官网 我猜去全部机翻+个人 ...
- Expo大作战(二)--expo的生命周期,expo社区交流方式,expo学习必备资源,开发使用expo时关注的一些问题
简要:本系列文章讲会对expo进行全面的介绍,本人从2017年6月份接触expo以来,对expo的研究断断续续,一路走来将近10个月,废话不多说,接下来你看到内容,讲全部来与官网 我猜去全部机翻+个人 ...
- Expo大作战(五)--expo中app.json 文件的配置信息
简要:本系列文章讲会对expo进行全面的介绍,本人从2017年6月份接触expo以来,对expo的研究断断续续,一路走来将近10个月,废话不多说,接下来你看到内容,讲全部来与官网 我猜去全部机翻+个人 ...
- Expo大作战(六)--expo开发模式,expo中exp命令行工具,expo中如何查看日志log,expo中的调试方式
简要:本系列文章讲会对expo进行全面的介绍,本人从2017年6月份接触expo以来,对expo的研究断断续续,一路走来将近10个月,废话不多说,接下来你看到内容,将全部来与官网 我猜去全部机翻+个人 ...
- Expo大作战(七)--expo如何使用Genymotion模拟器
简要:本系列文章讲会对expo进行全面的介绍,本人从2017年6月份接触expo以来,对expo的研究断断续续,一路走来将近10个月,废话不多说,接下来你看到内容,将全部来与官网 我猜去全部机翻+个人 ...
- Expo大作战(八)--expo中的publish以及expo中的link,对link这块东西没有详细看,大家可以来和我交流
简要:本系列文章讲会对expo进行全面的介绍,本人从2017年6月份接触expo以来,对expo的研究断断续续,一路走来将近10个月,废话不多说,接下来你看到内容,将全部来与官网 我猜去全部机翻+个人 ...
- Expo大作战(十三)--expo如何自定义状态了statusBar以及expo中如何处理脱机缓存加载 offline support
简要:本系列文章讲会对expo进行全面的介绍,本人从2017年6月份接触expo以来,对expo的研究断断续续,一路走来将近10个月,废话不多说,接下来你看到内容,讲全部来与官网 我猜去全部机翻+个人 ...
- Expo大作战(十一)--expo中的预加载和缓存资产(Preloading & Caching Assets),expo中的图标 (Icon)
简要:本系列文章讲会对expo进行全面的介绍,本人从2017年6月份接触expo以来,对expo的研究断断续续,一路走来将近10个月,废话不多说,接下来你看到内容,讲全部来与官网 我猜去全部机翻+个人 ...
- Expo大作战(九)--expo的工作原理,以及版本发行说明
简要:本系列文章讲会对expo进行全面的介绍,本人从2017年6月份接触expo以来,对expo的研究断断续续,一路走来将近10个月,废话不多说,接下来你看到内容,将全部来与官网 我猜去全部机翻+个人 ...
随机推荐
- @RequestParam注解
SpringMVC的参数指定注解:@RequestParam,有下面四个方法: value 参数绑定,value里写的是URL里参数名称 name 同上 required 是否必需参数,默认为tr ...
- 使用 IntelliJ IDEA 导入 Spark 最新源码及编译 Spark 源代码(博主强烈推荐)
前言 其实啊,无论你是初学者还是具备了有一定spark编程经验,都需要对spark源码足够重视起来. 本人,肺腑之己见,想要成为大数据的大牛和顶尖专家,多结合源码和操练编程. 准备工作 1.sca ...
- epoll 触发模式
Edge Triggered (ET):边缘触发只有数据到来,才触发,不管缓存区中是否还有数据.Level Triggered (LT):水平触发只要有数据都会触发. LT(level trigger ...
- Edge和Chrome浏览器滚屏截取网页
1.Edge打开需要截图的页面,选择下面的功能: 在页面按下左键选中需要截图的区域(不要放开左键,这时可以滚动鼠标滚轮到底部),放开左键后就完成截图,直接可以粘贴到QQ或其他地方. 2,Chrome截 ...
- 【转载】表单中 Readonly 和 Disabled 的区别
今天写代码,遇到表单提交的问题,某个字段在不同的情况下,要传递不同的值进行赋值,试过一些方法都有些问题,后来请教前端同学,使用 disabled 这个属性终于搞定了问题,查到一篇讲解 readonly ...
- [Python学习笔记-004] 可变参数*args和**kwargs
在Python中,可变参数的传递使用*args和**kwargs来实现,其中: *args表示任意个位置参数(positional argument),被表示为一个只读的数组(tuple): **kw ...
- js的轮播效果
图片的轮播效果!主要运用了元素的style样式属性,与 setInterval(); <!DOCTYPE html> <html> <head lang="en ...
- notepad++ jstool 插件安装
notepad++ 格式化显示 网上下载 jstool 插件 放入Notepad++\安装目录的plugins位置下,重启即可使用 插件-->JSTool
- 【LeetCode题解】844_比较含退格的字符串(Backspace-String-Compare)
目录 描述 解法一:字符串比较 思路 Java 实现 Python 实现 复杂度分析 解法二:双指针(推荐) 思路 Java 实现 Python 实现 复杂度分析 更多 LeetCode 题解笔记可以 ...
- 【SpringBoot系列5】SpringBoot整合RabbitMQ
前言: 因为项目需要用到RabbitMQ,前几天就看了看RabbitMQ的知识,记录下SpringBoot整合RabbitMQ的过程. 给出两个网址: RabbitMQ官方教程:http://www. ...