Sentry for vue - Raven.js

在vue官方文档看到这个推荐的错误追踪服务- sentry,去官网看了看觉得挺不错的,就准备用到项目里。
嗯,还有官方集成vue,那太棒了,结果官方文档在vue中的使用说明只有寥寥几行,仅仅说明了如何引入与集成,完全没说在组件中如何使用(可能是我英文水平太low,没看出来)。那么只得靠自己了,自己封装一下。
主要还是看文档,在JavaScript栏目下,如何使用已经说明的很清楚了,我要做的仅仅是封装一个插件,使其在组件内可以直接使用。不多bb,直接上代码。

let Log = function() {};

/**
 * 写普通日志
 * @param {String} title 
 * @param {String} context 
 * @param {String} level 
 * @param {Object} tags 
 */
Log.writeNormalLog = function(title='',context='',level='info',tags={}) {
    Raven.captureMessage(title,{level,tags,extra:{context}});
};

/**
 * 写异常日志
 * @param {String} title 
 * @param {String} context 
 * @param {String} level 
 * @param {Object} tags 
 */
Log.writeExLog = function(ex,context='',level='info',tags={}) {
    Raven.captureException(ex,{level,tags,extra:{context}});
};


Log.Level={
    INFO:'info',
    WARNING:'warning',
    ERROR:'error'
};

export default {
  /**
     * Raven.js 日志记录插件
     * Doc:https://docs.sentry.io/clients/javascript/usage/
     * @param {*} Vue 
     * @param {Object} options 
     */
  install(Vue, options = {}) {
    Raven.config("your dsn")
      .addPlugin(RavenVue, Vue)
      .install();

    Raven.setUserContext({
      user: options.user || ""
    });

    Raven.setTagsContext({ environment: options.env });

    Object.defineProperties(Vue.prototype, {
      $log: { value: Log, writable: true }
    });
  }
};

Log即为封装的日志记录方法,这里只是简单的使用了几个参数。
setUserContext 用来记录用户信息。
setTagsContext 设置全局tag标签,任何记录都会带上这个tag,这里记录了运行环境。

使用中发现一个问题,就是时区不正确,找了半天才发现在哪改


点击左下角的图标,选择账户(Account),在外观(Appearance)中修改时区。


更新一下关于sourcemap的,一般生产环境都会压缩js,异常常常是1行3000列这种情况,这时通过sourcemap可以解决这个问题,这里不细说sourcemap。
想要在sentry上通过sourcemap显示具体信息就需要上传相关脚本的sourcemap,官方文档上表明有2种方法,我使用的sentry-cli来上传的。

具体流程

  1. 安装sentry-cli $ npm install sentry-cli-binary -g
  2. 登录sentry,这里需要用到token $ sentry-cli login
    关于token则是在如图左下角,点击API

    创建一个token,记住要勾选 project:write 开启项目的写权限
  3. 创建一个release $ sentry-cli releases -o MY_ORG -p MY_PROJECT new NAME
  4. $ sentry-cli releases -o MY_ORG -p MY_PROJECT files NAME upload-sourcemaps --url-prefix URL_PREFIX DIR
    MY_ORG 为组织名称,可以使用简称,在组织设置里查看。
    MY_PROJECT 为项目名称
    NAME 为自定义的release名称
    URL_PREFIX 为url前缀,一般是js所在目录地址
    DIR 为需要上传文件所在目录

这是文档中的例子:$ sentry-cli releases -o MY_ORG -p MY_PROJECT files 2da95dfb052f477380608d59d32b4ab9 upload-sourcemaps --url-prefix https://mydomain.invalid/static path/to/assets 上传完后的sourcemap地址为 https://mydomain.invalid/static/xxxxxx.js.map

上传完成后只要地址正确就OK了

官方提示

  • Make sure that the URL prefix is correct for your files. This is easy to get wrong.
  • Make sure you upload the matching sourcemaps for your minimized files.
  • Make sure that your minified files you have on your servers actually have references to your files.

附:
sourcemap官方使用说明
Sentry Documentation

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 199,830评论 5 468
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 83,992评论 2 376
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 146,875评论 0 331
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 53,837评论 1 271
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 62,734评论 5 360
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,091评论 1 277
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,550评论 3 390
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,217评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,368评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,298评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,350评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,027评论 3 315
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,623评论 3 303
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,706评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,940评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,349评论 2 346
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 41,936评论 2 341

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,566评论 18 139
  • Spring Boot 参考指南 介绍 转载自:https://www.gitbook.com/book/qbgb...
    毛宇鹏阅读 46,713评论 6 342
  • 中文翻译 ng help ng build 构建您的应用程序并将其放入输出路径(dist /默认情况下)。 别名:...
    4ea0af17fd67阅读 1,993评论 0 0
  • App Programming Guide for iOS翻译 https://developer.apple.c...
    鋼鉄侠阅读 1,057评论 0 1
  • `小圆桌`是几个程序员、产品经理和设计师小伙伴一起兼职做的项目。 我们希望能够帮创业者解决一些实际的问题,同时也让...
    小圆桌阅读 295评论 0 1