五分钟教你用Rollbar在heroku上debug

为什么heroku上debug这么难?

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

五分钟教你用Rollbar在heroku上debug_第1张图片

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

五分钟教你用Rollbar在heroku上debug_第2张图片

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

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

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

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

1. 免费

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

五分钟教你用Rollbar在heroku上debug_第3张图片

2. 简单

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

3.实用

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

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

五分钟教程——配置篇:

Step1 注册

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

五分钟教你用Rollbar在heroku上debug_第4张图片

Step2 新建项目

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

五分钟教你用Rollbar在heroku上debug_第5张图片

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

五分钟教你用Rollbar在heroku上debug_第6张图片

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

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

Step3 在项目中添加gem 'rollbar'

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

五分钟教你用Rollbar在heroku上debug_第7张图片

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

Step4 配置

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

rails generate rollbar 刚刚复制的access token

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

rake rollbar:test

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

Step5 完成配置

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

五分钟教你用Rollbar在heroku上debug_第8张图片

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

五分钟教你用Rollbar在heroku上debug_第9张图片

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

五分钟教程——使用篇:

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

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

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

本地错误提示

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

五分钟教你用Rollbar在heroku上debug_第10张图片

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

五分钟教你用Rollbar在heroku上debug_第11张图片

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

五分钟教你用Rollbar在heroku上debug_第12张图片

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

Heroku错误提示

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

五分钟教你用Rollbar在heroku上debug_第13张图片

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

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

五分钟教你用Rollbar在heroku上debug_第14张图片

总结

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

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

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

附件:

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

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

五分钟教你用Rollbar在heroku上debug_第15张图片
五分钟教你用Rollbar在heroku上debug_第16张图片

你可能感兴趣的:(五分钟教你用Rollbar在heroku上debug)