Laravel Telescope 未监听 Redis

最近新建一个5.8的项目,调用了Redis,但是在Telescope界面刷新了好几次,在Redis那里一直无数据,后来看了下源码,发现Telescope监听的是Redis的CommandExecuted:

public function register($app)
    {
        $app['events']->listen(CommandExecuted::class, [$this, 'recordCommand']);
    }

而Redis的configure函数中有进行相关判断

protected function configure(Connection $connection, $name)
    {
        $connection->setName($name);

        if ($this->events && $this->app->bound('events')) {
            $connection->setEventDispatcher($this->app->make('events'));
        }

        return $connection;
    }

但是Redis的$events属性默认为false,导致Reids执行命令时无法监听对应事件,解决思路就是修改Redis的这个$events属性了:

$this->app['redis']->enableEvents();
本作品采用《CC 协议》,转载必须注明作者和本文链接
《L03 构架 API 服务器》
你将学到如 RESTFul 设计风格、PostMan 的使用、OAuth 流程,JWT 概念及使用 和 API 开发相关的进阶知识。
《L02 从零构建论坛系统》
以构建论坛项目 LaraBBS 为线索,展开对 Laravel 框架的全面学习。应用程序架构思路贴近 Laravel 框架的设计哲学。
讨论数量: 2

这个很有意思,不看源码还真不知道这里有个开关,哈哈哈。

1年前 评论

讨论应以学习和精进为目的。请勿发布不友善或者负能量的内容,与人为善,比聪明更重要!