laravel+rabbitMQ

本文介绍如何在Laravel框架中集成RabbitMQ消息队列,包括安装配置Erlang环境、RabbitMQ服务器及客户端的过程,并提供了一个简单的示例。

laravel+rabbitMQ


前言

第一次学习消息队列rabbit,因为平时使用的是laravel,因此我打算把laravel和rabbit结合起来


提示:以下是本篇文章正文内容,下面案例可供参考

一、安装Erlang环境

1.安装erlang前安装下依赖文件

yum install gcc glibc-devel make ncurses-devel openssl-devel xmlto

2.去erlang官网下载erlang安装包

wget -c http://erlang.org/download/otp_src_22.3.tar.gz

3.解压

tar -zxvf otp_src_22.3.tar.gz
cd otp_src_22.3/

4.编译安装

./configure --prefix=/usr/local/erlang
make && make install

5.配置环境变量

vim /etc/profile
末尾加入一行:export PATH=$PATH:/usr/local/erlang/bin 
source /etc/profile

二、安装rabbitmq

1.下载

*wget -c https://github.com/rabbitmq/rabbitmq-server/releases/download/v3.8.8/rabbitmq-server-generic-unix-3.8.8.tar.xz

2.解压

xz -d rabbitmq-server-generic-unix-3.8.8.tar.xz
tar -xvf rabbitmq-server-generic-unix-3.8.8.tar*

3.操作

cd rabbitmq_server-3.8.8/sbin
启动:rabbitmq-server
关闭:rabbitmqctl stop
查看状态:rabbitmqctl status
启用插件: rabbitmq-plugins enable rabbitmq_management
访问管理页面:http://localhost:15672 端口默认为15672

4.添加用户

rabbitmqctl add_user admin admin //添加用户,后面两个参数分别是用户名和密码
rabbitmqctl set_permissions -p / admin “." ".” “.*” //添加权限
rabbitmqctl set_user_tags admin administrator //修改用户角色,将用户设为管理员

二、laravel安装rabbitmq

1.Composer 安装

composer require vladimir-yuldashev/laravel-queue-rabbitmq
安装的时候可能会报版本不符合错误
在这里插入图片描述

链接: laravel-queue-rabbitmq

这时候只要安装对应laravel的laravel-queue-rabbitmq版本即可

2.config/app.php ,providers 中添加:
VladimirYuldashevLaravelQueueRabbitMQLaravelQueueRabbitMQServiceProvider::class,
3.app/config/queue.php 配置中connections 数组中加入下列配置
'rabbitmq' => [

            'driver' => 'rabbitmq',
            'connection' => PhpAmqpLibConnectionAMQPLazyConnection::class,
            'dsn' => env('RABBITMQ_DSN', null),

            'factory_class' => EnqueueAmqpLibAmqpConnectionFactory::class,

            'host' => env('RABBITMQ_HOST', '127.0.0.1'),
            'port' => env('RABBITMQ_PORT', 5672),

            'vhost' => env('RABBITMQ_VHOST', '/'),
            'login' => env('RABBITMQ_LOGIN', 'guest'),
            'password' => env('RABBITMQ_PASSWORD', 'guest'),

            'queue' => env('RABBITMQ_QUEUE', 'default'),

            'options' => [

                'exchange' => [
                    'name' => env('RABBITMQ_EXCHANGE_NAME'),
                    'declare' => env('RABBITMQ_EXCHANGE_DECLARE', true),
                    'type' => env('RABBITMQ_EXCHANGE_TYPE', InteropAmqpAmqpTopic::TYPE_DIRECT),
                    'passive' => env('RABBITMQ_EXCHANGE_PASSIVE', false),
                    'durable' => env('RABBITMQ_EXCHANGE_DURABLE', true),
                    'auto_delete' => env('RABBITMQ_EXCHANGE_AUTODELETE', false),
                    'arguments' => env('RABBITMQ_EXCHANGE_ARGUMENTS'),
                ],

                'queue' => [
                    'name' => 'queuename',
                    'declare' => env('RABBITMQ_QUEUE_DECLARE', true),
                    'bind' => env('RABBITMQ_QUEUE_DECLARE_BIND', true),
                    'passive' => env('RABBITMQ_QUEUE_PASSIVE', false),
                    'durable' => env('RABBITMQ_QUEUE_DURABLE', true),
                    'exclusive' => env('RABBITMQ_QUEUE_EXCLUSIVE', false),
                    'auto_delete' => env('RABBITMQ_QUEUE_AUTODELETE', false),
                    'arguments' => env('RABBITMQ_QUEUE_ARGUMENTS'),
                ],
            ],
            'sleep_on_error' => env('RABBITMQ_ERROR_SLEEP', false),
            'ssl_params' => [
                'ssl_on' => env('RABBITMQ_SSL', false),
                'cafile' => env('RABBITMQ_SSL_CAFILE', null),
                'local_cert' => env('RABBITMQ_SSL_LOCALCERT', null),
                'local_key' => env('RABBITMQ_SSL_LOCALKEY', null),
                'verify_peer' => env('RABBITMQ_SSL_VERIFY_PEER', true),
                'passphrase' => env('RABBITMQ_SSL_PASSPHRASE', null),
            ],

        ],

这些配置githup有详细介绍

4.修改 .env 文件
QUEUE_DRIVER=rabbitmq

#以下是新增配置
RABBITMQ_HOST=192.168.111.174
RABBITMQ_PORT=5672  #mq的端口
RABBITMQ_VHOST=/
RABBITMQ_LOGIN=admin    #mq的登录名
RABBITMQ_PASSWORD=admin   #mq的密码
RABBITMQ_QUEUE=queuename   #mq的队列名称
5.封装rabbitMQ类(测试用)
<?php

namespace AppModuleQueue;

use PhpAmqpLibConnectionAMQPStreamConnection;
use PhpAmqpLibMessageAMQPMessage;

class RabbitMQ
{
    //创建静态私有的变量保存该类对象
//    static private $connectionInstance;

    //防止使用new直接创建对象
    private function __construct(){}

    //防止使用clone克隆对象
    private function __clone(){}

//    public static function getConnectionInstance(){
//        if (empty(self::$connectionInstance)) {
//            $config = config('queue.connections.rabbitmq');
//            self::$connectionInstance = new AMQPStreamConnection($config['host'], $config['port'], $config['login'], $config['password'], $config['vhost']);
//        }
//        return self::$connectionInstance;
//    }


    private static function getConnect(){
        $config = config('queue.connections.rabbitmq');
        return new AMQPStreamConnection($config['host'], $config['port'], $config['login'], $config['password'], $config['vhost']);
    }

    public static function push($queue, $messageBody, $exchange = 'router'){
        $connection = self::getConnect();
        $channel = $connection->channel();
        $channel->queue_declare($queue, false, true, false, false);
        $channel->exchange_declare($exchange, 'direct', false, true, false);
        $channel->queue_bind($queue, $exchange); // 队列和交换器绑定
        $message = new AMQPMessage($messageBody, array('content_type' => 'text/plain', 'delivery_mode' => AMQPMessage::DELIVERY_MODE_PERSISTENT));
        $channel->basic_publish($message, $exchange); // 推送消息
        $channel->close();
        $connection->close();
    }

    public static function pop($queue, $callback, $exchange = 'router'){
        $connection = self::getConnect();
        $channel = $connection->channel();
        $message = $channel->basic_get($queue); //取出消息
        $res = $callback($message->body);
        if($res){
            $channel->basic_ack($message->getDeliveryTag());
        }
        $channel->close();
        $connection->close();
    }
}
6.laravel创建任务类
php artisan make:job TestQueue

在终端内执行上述命令,会自动生成 app/Jobs/TestQueue.php 文件
这里附上测试代码

<?php

namespace AppJobs;

use AppModuleQueueRabbitMQ;
use IlluminateBusQueueable;
use IlluminateQueueSerializesModels;
use IlluminateQueueInteractsWithQueue;
use IlluminateContractsQueueShouldQueue;
use IlluminateFoundationBusDispatchable;

class TestQueue implements ShouldQueue
{
    use Dispatchable, InteractsWithQueue, Queueable, SerializesModels;

    /**
     * Create a new job instance.
     *
     * @return void
     */
    public function __construct($array = [])
    {
        RabbitMQ::push('test_queue', $array['msg']);
    }

    /**
     * Execute the job.
     *
     * @return void
     */
    public function handle()
    {
        RabbitMQ::pop('test_queue', function ($message){
            print_r($message);
            return true;
        });
    }

    public function failed(Exception $exception)
    {
        // 给用户发送任务失败的通知,等等……
    }
}
6.将队列运行起来
php artisan queue:work

在这里插入图片描述

7.把数据放进 mq 队列

这里我新建了一个控制器来调用

TestQueue::dispatch(['msg' => 'testMsg']); //这里把msg传到TestQueue的__construct

下面我们来测试一下
当执行到了TestQueue::dispatch([‘msg’ => ‘testMsg’]);这里之后
终端显示
在这里插入图片描述


总结

最近刚学了rabbitMQ想把它结合laravel用起来,rabbitMQ还有很多需要学习的地方。以上有不足或者问题之处请各位指出。

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值