laravel 控制器中使用中间件_在 Laravel 中使用 Slack 进行异常通知

a5f6f9ee6a0791f2edeab447fdc80c0e.png

php中文网最新课程

每日17点准时技术干货分享

f64f5da8470e7669a37e17ce52d0898d.png

4b1bbdfba71418f3403166f7b7e2144a.gif

异常处理是软件开发过程中无法逃避的问题。对于一套设计良好代码高效的程序,出现异常的可能性会比较低,但这并不意味着不会出现异常,有些异常甚至会引起严重的后果,所以如何及时的发现程序中的异常并处理它便显得十分重要了。

通常,我们可以依靠用户反馈、经常查看程序日志来发现程序存在的问题。

但这要么不可靠要么不及时,所以下面我们介绍一种比较有效的做法--使用 Slack 通知程序跑出的异常信息。

Slack 是一款即时通信软件,类似于 QQ,它提供开放的 API,可以调用它向自己团队中指定的个人或者频道(Channel)发送消息,因此用它来进行异常通知是再合适不过的。

1.安装 maknz/slack-laravel 包

具体的安装方法请参考 Github 上的 [readme](https://github.com/maknz/slack-laravel)。

2.配置

安装完成后使用 php artisan vendor:publish 生成 config\slack.php 配置文件,然后在.env文件中添加如下三项配置值.```SLACK_ENDPOINT=//slack 终端,即 slack 接口地址SLACK_CHANNEL=//消息默认接收频道SLACK_USERNAME//消息默认接收人```> 当然,也可以直接直接在 config\slack.php 对应配置的默认值而不使用 .env,但并不推荐这样做。> 根据实际需要设置 SLACK_CHANNEL 和 SLACK_USERNAME ,二者并不是必须的

3.调整 AppExceptionsHandler 类的 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 团队中已经存在的,不然会出错。

这样,当程序中出现异常时,运维能在第一时间收到相关的通知信息,方便及时处理了。

36fbed150a7139808d59782419c4ecc6.png

6c505ed90f4e4aa09ddd33bf3b83fd65.png

cf7bda710e5ab3ae1e816d66b4b99e9e.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值