原生PHP+Redis队列

1905

(1).创建一个验证码发送接口

/**
 * 发送验证码
 */
public function sendCaptcha()
{
    //外部参数(获取手机号)
    $mobile = $_REQUEST['mobile'] ?? 0;
    if (!$mobile)
    {
        exit(json_encode(['code' => -1, 'msg' => '手机号码不得为空'], 256));
    }
    //生成短信验证码(随机数4位)
    $captcha = rand(1111, 9999);
    //组装队列数据Json
    $send_data = [
        'mobile' => $mobile,
        'captcha' => $captcha,
    ];
    //连接本地的Redis 服务
    $redis = new \Redis();
    $redis->connect('127.0.0.1', 6379);
    //向Redis的send_captcha队列投递数据
    $isPush = $redis->lPush('send_captcha', json_encode($send_data));
    if (!$isPush)
    {
        exit(json_encode(['code' => -1, 'msg' => '验证码发送失败'], 256));
    }
    //输出发送成功
    exit(json_encode(['code' => 0, 'msg' => '验证码发送成功'], 256));
}

(2).创建一个命令行队列处理脚本console.php

<?php
//连接本地的Redis 服务
$redis = new \Redis();
$redis->connect('127.0.0.1', 6379);
//循环从Redis的send_captcha队列提取数据
while (true)
{
    //从队列提取数据,超时时间5秒
    //$content正常返回第一个元素是队列名称,第二个元素是你保存的值
    $content = $redis->brPop('send_captcha', 5);
    if ($content)
    {
        //提取数据中的手机号和验证码
        $data = json_decode($content['1'], true);
        $mobile = $data['mobile'];
        $captcha = $data['captcha'];
        //进行发送,此处为伪代码
        //sendCode($mobile,$captcha);
        //输出日志
        echo "向{$mobile}发送验证码{$captcha}成功" . PHP_EOL;
    }
}

(3).模拟请求验证码接口

curl http://xxxx.com/sendCaptcha
//输出
{"code":0,"msg":"验证码发送成功"}

(4).启动命令行脚本php console.php,脚本输出如下

向136313xxxxxx发送验证码6188成功

解析:通过向接口提交手机号,接口会把要发送的手机号和验证码保存到队列,而另外1个命令行脚本会监听队列并及时发送验证码。假如同时来100人同时发送验证码也不担心会阻塞导致网络带宽资源耗尽。