为什么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分钟读书法