五分钟教你用Rollbar在heroku上debug

为什么heroku上debug这么难?

我们在做项目的时候,有时候在本地运行的好好的,但是部署到heroku的时候就出现错误。出错不可怕,可怕的是不知道错在哪里,下面的是heroku的错误提示,只告诉你"something went wrong"。你要想问然后呢?哦,下面还有行小字,如果你是网站拥有者,你可以查看logs。

那我们用heroku logs 来看下:密密麻麻的一堆,而且这样的一堆还有好几页,虽然其实还是有线索的,但是这样找效率太低。看的人一脸生无可恋。

我知道你在想:「如果heroku能像localhost一样直接来个报错,告诉我们错误在哪里就爽了。」

梦想成真——第三方工具来救驾

正是因为有这个需求,所以有不少第三方都在做这样的工具,比较出名的有Aribrake,功能强大,但是缺点也比较明显,最基础的套餐也要49刀一个月,对于还在只是部署个人网站或小型应用网站来说,太贵了。

那有没有便宜点的,你别说,还真有!那就是我们今天本文的主角:Rollbar,以下是它的三大特点:

1. 免费

简直业界良心好吗?免费的方案每月可以有五千条错误提示,错误记录保留30天。用于个人网站和普通网站的测试来说完全够用。

2. 简单

跟着下面的教程傻瓜式操作,五分钟包教会。

3.实用

不但在部署不成功会提示,而且在部署成功后,网站在正常运行期间如果出问题的话也会提示。非常方便。

多说无益,请直接打开电脑跟着我操作。

五分钟教程——配置篇:

Step1 注册

打开官网https://rollbar.com/ 直接注册一个账号。也可以使用你的Github账号直接登录。

Step2 新建项目

注册完成后直接回跳转到新建项目页面,如下图:

记住选中Rails,然后再输入框内输入项目名称,再点击'continue'。就会进入使用介绍页面,如下图:

这一步我们可以把生成的Server-side access token(上图红框处)复制下来备用。

提示:这个网页暂时不要关闭。

Step3 在项目中添加gem 'rollbar'

这时候切换到本地的专案,用atom打开gemfile,添加gem 'rollbar'group :development, :test do之前。

保存Gemfile,然后在iterm中执行bundle install

Step4 配置

顺次在iterm中执行下面的代码:

rails generate rollbar 刚刚复制的access token

heroku config:add ROLLBAR_ACCESS_TOKEN=刚刚复制的access token

rake rollbar:test

执行完成后,你的注册邮箱应该会收到一封电子邮件,就是最后一句代码发出测试的反馈信息。

Step5 完成配置

上一步完成之后,我们再回到Rollbar刚刚的网页。点击底部硕大的按钮,下图红框处:

然后就会进入控制面板,里面可以显示heroku的错误:

好,到这一步,配置就完成了,以后就能愉快的使用了。下面我们来展示一下到底怎么用。

五分钟教程——使用篇:

那安装好了,怎么用呢?其实不用做额外的操作,一旦本地或者heroku上发生错误,Rollbar会自动给你发邮件提示。然后根据具体的错误信息debug就行了。

为了演示这个效果,我直接把我的项目的首页的index.html.erb给删了。来看看Rollbar会怎么给我提示。

Rollbar虽然主要用来在heroku上debug,但是在development环境下出现的错误也是会提示的。我们下面就分成两部分来看:

本地错误提示

刚刚人为设置好没有首页的错误之后,开rails s,地址栏输入localhosts:3000,直接会报错如下:

同时Rollbar会给我发一封邮件,也是一样的错误

点开上图链接后会进入详情界面,如下图,上面的红框提示开发环境是development,下面的红框是详细的报错信息。

是不是和本地debug报错信息一样的丰富?但是你会说,这不是多此一举么?本地本来就有报错信息啊?是的,如果只是在本地的话,确实没必要使用为的工具。但Rollbar的真正作用是在heroku上面遇到错误也会给详细提示,咱们接着看。

Heroku错误提示

本地虽然出错了,但是我不管不顾还是push到heroku上面了,然后打开heroku项目网址一看,什么情况?怎么不提示错误呢?而且首页怎么加载的这么慢?十几秒过去了,还是一片空白。

这时候,我的手机“叮”了一声,一看是邮箱收到Rollbar的错误提示邮件了。顿时热泪盈眶有没有!

我们来看看错误详情,这次注意红框处变成了production,也就是生产环境。报错信息也非常的丰富,和本地相比几乎没差别。是不是很完美!

总结

避免Heroku上出现bug的最好的思路应该是这样:

首先,保证在本地测试的时候一定要完整无bug。

其次,如果本地一切正常,Heroku还是有bug的话,再请Rollbar出马。

附件:

在写该文时用到的16格笔记和思维导图。

关于16格比较,你可以参考这篇文章:神奇的三30分钟读书法

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

推荐阅读更多精彩内容