PHP+Laravel框架RabbitMQ简单使用

RabbitMQ安装教程请转到:RabbitMQ安装教程(超详细)

1、创建生产者

在app/Http/Controllers里创建一个php控制器文件,

namespace App\Http\Controllers;

use App\Http\Controllers\Controller;
//引入amqp扩展
use PhpAmqpLib\Connection\AMQPStreamConnection;
use PhpAmqpLib\Message\AMQPMessage;
use PhpAmqpLib\Wire\AMQPTable;


require_once(__DIR__.'/../../../../vendor/autoload.php');

class TestController extends Controller {
    
    public function production() {
        //创建服务器连接
        $connection = new AMQPStreamConnection('172.16.5.114', 5672, 'admin', '123456');
        //连接信道
        //信道是生产消费者与rabbit通信的渠道,生产者publish或者消费者消费一个队列都是需要通过信道来通信的
        //信道是建立在TCP上面的虚拟链接,也就是rabbitMQ在一个TCP上面建立成百上千的信道来达到多个线程处理。
        //注意是一个TCP 被多个线程共享,每个线程对应一个信道,信道在rabbit都有唯一的ID,保证了信道的私有性,对应上唯一的线程使用。
        $channel = $connection->channel();

        //channel->queue_declare通过信道创建一个是否是持久化的消息队列
        //queue第一个参数代表消息队列名称
        $channel->queue_declare('test_queue', false, false, false, false);

        //往队列里要发送内容,待发送的内容
        $data = '这是一个生产者消息' . date('Y-m-d H:i:s');
        $msg = new AMQPMessage($data);
        //通过信道来进行发送消息
        //而exchange是怎么知道消息应该推到哪个queue呢,这就要通过绑定queue与exchange时的routingkey了,通过代码进行绑定并且指定routingkey,下面有一张关系图,p(发布者) —> x(exchange) bindding(绑定关系也就是我们的routingkey) 红色代表着queue
        $channel->basic_publish($msg, '', 'test_queue');

        echo " [x] Sent '这是一个生产者消息!'\n";

        //关闭信道
        $channel->close();
        //关闭连接
        $connection->close();
    }
}

在routes/web.php中加一下路由

use App\Http\Controllers\TestController;

Route::get('/test/production', [TestController::class, 'production']);

运行下就可以生成队列了

PHP+Laravel框架RabbitMQ简单使用_第1张图片

 2、创建消费者

在app/Console/Commands下创建一个php文件,比如TestQueue.php

channel();

        //channel->queue_declare通过信道创建一个是否是持久化的消息队列
        //queue第一个参数代表消息队列名称
        $channel->queue_declare('test_queue', false, false, false, false);

        echo " [*] Waiting for messages. To exit press CTRL+C\n";

        //进行监听消费者是否有消息,如果有进行输出消息内容
        $callback = function ($msg) {
            echo ' [x] Received ', $msg->body, "\n";
        };

        //通过信道进行消费消息
        $channel->basic_consume('test_queue', '', false, true, false, false, $callback);

        //如果信道是打开状态
        while ($channel->is_open()) {
            //然后让信道一直处于监听等待状态
            $channel->wait();
        }

        //关闭信道
        $channel->close();
        //关闭连接
        $connection->close();
    }
}

修改app/Console/Kernel.php文件,即$commands增加TestQueue::class

command('inspire')
        //          ->hourly();
    }

    /**
     * Register the commands for the application.
     *
     * @return void
     */
    protected function commands()
    {
        $this->load(__DIR__.'/Commands');

        require base_path('routes/console.php');
    }
}

3、使用command进行测试

先cd到项目根目录,执行下面命令

php artisan rabbitmq_TestQueue

就消费了消息

PHP+Laravel框架RabbitMQ简单使用_第2张图片

 按 Ctrl+c 结束

生产环境可以使用守护进程

PHP+Laravel框架RabbitMQ简单使用_第3张图片

 

 PHP+Laravel框架RabbitMQ简单使用_第4张图片

 

 

你可能感兴趣的:(中间件,laravel,laravel,php,RabbitMQ)