欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

浅谈Laravel中使用Slack进行异常通知

程序员文章站 2022-03-08 07:59:55
概述通常,我们可以依靠用户反馈、经常查看程序日志来发现程序存在的问题。但这要么不可靠要么不及时,所以下面我们介绍一种比较有效的做法--使用 slack 通知程序跑出的异常信息。slack 是一款即时通...

概述

通常,我们可以依靠用户反馈、经常查看程序日志来发现程序存在的问题。但这要么不可靠要么不及时,所以下面我们介绍一种比较有效的做法--使用 slack 通知程序跑出的异常信息。

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

安装 maknz/slack-laravel 包

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

配置

安装完成后使用 php artisan vendor:publish 生成 config\slack.php 配置文件,然后在.env文件中添加如下三项配置值.

slack_endpoint=//slack 终端,即 slack 接口地址

slack_channel=//消息默认接收频道

slack_username//消息默认接收人

> 当然,也可以直接直接在 config\slack.php 对应配置的默认值而不使用 .env,但并不推荐这样做。

> 根据实际需要设置 slack_channel 和 slack_username ,二者并不是必须的

调整 appexceptionshandler 类的 report 方法

实现 slack 通知异常信息的逻辑。代码如下:

/**
 
 * report or log an exception.
 
 *
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中使用slack进行异常通知的资料请关注其它相关文章!