• 技术文章 >后端开发 >PHP7

    PHP7之Reids键空间通知配合TP5 实现分布式延时任务

    藏色散人藏色散人2019-08-29 17:58:48转载1719
    本篇文章主要给大家介绍Reids 键空间通知配合TP5 实现分布式延时任务,希望对需要的朋友有所帮助!

    1e572951d89f44eef79b80328c622bf.png

    测试环境:windows 10 + phpStudy

    配置redis配置文件 redis.windows.conf

    notify-keyspace-events "Ex"

    重启redis服务

    f82303ef78b1835d19a4c809e5bed8f.png

    重新打开一个控制台窗口,执行命令

    psubscribe __keyevent@0__:expired

    打开新窗口执行了阻塞订阅操作后的终端,等会会有信息输出:

    C:\Users\admin>redis-cli
    127.0.0.1:6379> psubscribe __keyevent@0__:expired
    Reading messages... (press Ctrl-C to quit)
    1) "psubscribe"
    2) "__keyevent@0__:expired"
    3) (integer) 1

    再开启一个终端,redis-cli 进入 redis,新增一个 6秒过期的键 username:
    05c43475f1596a28dbecf6ea32ec16f.png

    命令行完成了

    二、借助TP5.1 的命令行工具

    命令行工具的使用:https://www.kancloud.cn/manual/thinkphp5_1/354146

    1、新建命令行pay

    <?php
    /**.-------------------------------------------------------------------------------------------------------------------
     * |  Github: https://github.com/Tinywan
     * '------------------------------------------------------------------------------------------------------------------*/
     
    namespace app\common\command;
     
    use app\pay\service\RedisSubscribe;
    use think\console\Command;
    use think\console\Input;
    use think\console\input\Argument;
    use think\console\Output;
     
    class Pay extends Command
    {
        // 配置指令
        public function configure()
        {
            $this->setName('pay')
              ->addArgument('type', Argument::REQUIRED, "the type of the task that pay needs to run")
              ->setDescription('this is payment system command line tools');
        }
     
        // 执行指令
        public function execute(Input $input, Output $output)
        {
            $type = $input->getArgument('type');
            if ($type == 'psubscribe') {
                // 发布订阅任务
                $this->psubscribe();
            }
        }
     
        /**
         * Redis 发布订阅模式
         */
        private function psubscribe()
        {
            $service = new RedisSubscribe();
            $service->sub();
        }
    }

    2、编写脚本 RedisSubscribe.php

    <?php
    /**.-------------------------------------------------------------------------------------------------------------------
     * |  Github: https://github.com/Tinywan
     * '------------------------------------------------------------------------------------------------------------------*/
     
    namespace app\pay\service;
     
    use redis\BaseRedis;
    use think\facade\Log;
     
    class RedisSubscribe
    {
        public function sub()
        {
            Log::error(get_current_date().'--过期事件的订阅-- ');
            $redis = BaseRedis::location(); //这里是直接连接本地redis
            $redis->setOption(\Redis::OPT_READ_TIMEOUT, -1);
            $redis->psubscribe(array('__keyevent@0__:expired'), function ($redis, $pattern, $chan, $msg) {
                Log::error('[1]--过期事件的订阅 ' . $msg);
            });
        }
    }

    说明:psubscribe( patterns,patterns,callback ) 方法的第二个参数为一个回调函数,这里我使用闭包作为一个回调。

    官方解释:匿名函数(Anonymous functions),也叫闭包函数(closures),允许 临时创建一个没有指定名称的函数。最经常用作回调函数(callback)参数的值。当然,也有其它应用的情况。

    3、在TP5 项目根目录执行pay 命令工具

    php think pay psubscribe

    4、新打开console 窗口终端

    C:\Users\admin>redis-cli
    127.0.0.1:6379> setex UserName 10 Tinywan
    OK
    127.0.0.1:6379> get UserName
    "Tinywan"
    127.0.0.1:6379> get UserName
    (nil)
    127.0.0.1:6379>

    5、查看打日志文件,看有没有接收到过期的key

    7b0aefb0bbf05f1ab67c300e1182e74.png

    6、最终的结果如下所示

    aa6a20826cadb091c3cca0d72c04bc6.png

    更高级的慢慢扩展

    1、自动取消订单

    2、订单完成后发送短信

    3、延迟任务等等

    相关推荐:《PHP7教程

    以上就是PHP7之Reids键空间通知配合TP5 实现分布式延时任务的详细内容,更多请关注php中文网其它相关文章!

    声明:本文转载于:Tinywan,如有侵犯,请联系admin@php.cn删除
    上一篇:PHP7之孤儿进程与僵尸进程 下一篇:php7 安装指南(windows)之apache安装(一)
    大前端线上培训班

    相关文章推荐

    • 如何统计reids内的特定key• TP5简单实现类似淘宝多级商品筛选功能(代码示例)• TP5实现表格拖动排序并保存到数据库的方法(附代码)• PHP7内核剖析之I/O模型

    全部评论我要评论

  • 取消发布评论发送
  • 1/1

    PHP中文网