在 Laravel 中使用 Slack 进行异常通知
来源:互联网 发布:虚拟机ubuntu怎样重置 编辑:程序博客网 时间:2024/04/30 08:22
异常处理是软件开发过程中无法逃避的问题。对于一套设计良好代码高效的程序,出现异常的可能性会比较低,但这并不意味着不会出现异常,有些异常甚至会引起严重的后果,所以如何及时的发现程序中的异常并处理它便显得十分重要了。
通常,我们可以依靠用户反馈、经常查看程序日志来发现程序存在的问题。但这要么不可靠要么不及时,所以下面我们介绍一种比较有效的做法–使用 Slack 通知程序跑出的异常信息。
Slack 是一款即时通信软件,类似于 QQ,它提供开放的 API,可以调用它向自己团队中指定的个人或者频道(Channel)发送消息,因此用它来进行异常通知是再合适不过的。
安装 maknz/slack-laravel 包
具体的安装方法请参考 Github 上的 readme。
配置
安装完成后使用 php artisan vendor:publish 生成 config\slack.php 配置文件,然后在.env文件中添加如下三项配置值.
```
SLACK_ENDPOINT=//slack 终端,即 slack 接口地址
SLACK_CHANNEL=//消息默认接收频道
SLACK_USERNAME//消息默认接收人
```当然,也可以直接直接在 config\slack.php 对应配置的默认值而不使用 .env,但并不推荐这样做。
根据实际需要设置 SLACK_CHANNEL 和 SLACK_USERNAME ,二者并不是必须的
调整 \App\Exceptions\Handler 类的 report 方法,实现 Slack 通知异常信息的逻辑。代码如下:
/** * Report or log an exception. * * This is a great spot to send exceptions to Sentry, Bugsnag, etc. * * @param \Exception $e * @return void */ public function report(Exception $e) { if ($this->shouldReport($e)) { $slackMessage = "\n[Error.{$e->getCode()}] {$e->getMessage()}"; $slackMessage.= "\n[Line.{$e->getLine()}] {$e->getFile()}"; $slackMessage.= "\n[Time] ".date('Y-m-d H:i:s'); try { Slack::to(config('slack.channel'))->send($slackMessage); } catch (\Exception $eOther) { \Log::info($slackMessage); } } return parent::report($e); }
对于一些可能频繁出现但又不致命的异常,例如404 NotFoundHttpException,我们可能并不想让程序通知它。为此,我们只需要在 Aop\Exceptions\Handler 类里的 $dontReort 属性中加入指定的异常的类型就可以了。
protected $dontReport = [ NotFoundHttpException::class, // ... ];
示例中展示的是对指定的频道(channel)发送信息,当然你还可以向指定的人发送,或者其它更复杂的用法。不过要注意指定的用户名和频道是自己 slack 团队中已经存在的,不然会出错。
这样,当程序中出现异常时,运维能在第一时间收到相关的通知信息,方便及时处理了。
- 在 Laravel 中使用 Slack 进行异常通知
- 在Laravel中使用数据库事务以及事务失败后的异常处理
- 在 Laravel 中使用 Laravel Searchy 遇到的坑
- android中使用EventBus进行消息通知
- 在laravel框架中使用mongodb数据库
- 在 CodeIgniter 中使用 Laravel Eloquent ORM
- 在Laravel中使用Redis报错
- Laravel 在构造方法中使用session
- 在使用SSH过程中,在JSP页面中对数据进行处理,出异常!
- Laravel 实例教程 —— 如何在Laravel 5.1中进行自定义包开发
- Laravel 实例教程 —— 如何在Laravel 5.1中进行自定义包开发
- 如何在Application中进行异常处理
- laravel中TokenMismatchException异常处理
- 详解在android中使用通知
- laravel 使用MAMP进行安装
- laravel使用ElasticSearch进行搜索
- 关于iOS中使用通知进行传值
- 关于在子线程中在run方法执行完之后通知主线程进行操作的方法。(Toast在子线程中无法使用)
- 《设计模式之单例模式》
- 2016微软探星夏令营:#1341 : Constraint Checker
- GTest学习之旅第一步
- 在Android Studio 取消打包某一个Jar包
- 分享Android 蓝牙4.0(ble)开发的解决方案
- 在 Laravel 中使用 Slack 进行异常通知
- poj 2442 Sequence
- 一个人的旅行
- mysql数据库中文乱码问题,修改mysql字符集(Linux Windows)
- 如何从手机音频口获得电能
- IDEA 常用快捷键
- java库Html2Image:实现html转图片功能
- hdu 1087 Super Jumping! Jumping! Jumping! (动态规划,求最长子序列之和)
- Android apk瘦身之使用TinyPng压缩图