yii2用php-amqplib使用rabbitmq

1.将php-amqplib拷贝至yii2项目,新建phpclient类  

<?php
use PhpAmqpLib\Connection\AMQPStreamConnection;
use PhpAmqpLib\Message\AMQPMessage;

class PhpClient
{
   public static function Call($n){
       require_once __DIR__ . '/vendor/autoload.php';

       $connection = new AMQPStreamConnection('localhost', 5672, 'guest', 'guest');
       $channel = $connection->channel();

       $channel->queue_declare('task_queue', false, true, false, false);

       $data=empty($n)?"Hello World!":$n;

       $msg = new AMQPMessage($data,
           array('delivery_mode' => AMQPMessage::DELIVERY_MODE_PERSISTENT)
       );

       $channel->basic_publish($msg, '', 'task_queue');

       $channel->close();
       $connection->close();

       return true;
   }
}

2.commands中新建controller简单实现tasker和worker

<?php
namespace app\commands;

use yii\console\Controller;
use Yii;
use PhpAmqpLib\Connection\AMQPStreamConnection;

class RabbittaskController extends Controller
{
    public function actionWorker()
    {
        require(Yii::getAlias('@vendor') . '/rabbitmq/vendor/autoload.php');

        $connection = new AMQPStreamConnection('localhost', 5672, 'guest', 'guest');
        $channel = $connection->channel();

        $channel->queue_declare('task_queue', false, true, false, false);

        $callback = function ($msg) {
       //$msg->body
            //do sth

            $msg->delivery_info['channel']->basic_ack($msg->delivery_info['delivery_tag']);
        };

        $channel->basic_qos(null, 1, null);
        $channel->basic_consume('task_queue', '', false, false, false, false, $callback);

        while (count($channel->callbacks)) {
            $channel->wait();
        }

        $channel->close();
        $connection->close();
    }

    public function actionNewTask()
    {
        require(Yii::getAlias('@vendor') . '/rabbitmq/PhpClient.php');
        \PhpClient::Call('test!');
    }
}

 

转载于:https://www.cnblogs.com/luotingliang/p/7267253.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Yii2框架提供了对RabbitMQ的支持。你可以使用Yii2的消息队列组件来集成和管理RabbitMQ。 首先,确保已安装RabbitMQ并运行在你的环境中。然后,通过Composer安装yii2-rabbitmq扩展包: ``` composer require mikemadisonweb/yii2-rabbitmq ``` 安装完成后,在Yii2的配置文件中添加以下内容以启用RabbitMQ组件: ```php 'components' => [ 'rabbitmq' => [ 'class' => 'mikemadisonweb\rabbitmq\Configuration', 'connections' => [ 'default' => [ 'host' => 'localhost', 'port' => 5672, 'user' => 'guest', 'password' => 'guest', 'vhost' => '/', ], ], 'exchanges' => [ 'myExchange' => [ 'name' => 'exchange_name', 'type' => 'direct', ], ], 'queues' => [ 'myQueue' => [ 'name' => 'queue_name', 'exchangeName' => 'exchange_name', ], ], ], ], ``` 以上配置了默认的RabbitMQ连接、交换机和队列。你可以根据需要进行自定义配置。 使用RabbitMQ组件发送消息示例: ```php use yii\base\BaseObject; use mikemadisonweb\rabbitmq\components\Producer; class MyJob extends BaseObject implements \yii\queue\JobInterface { public function execute($queue) { $producer = new Producer(); $producer->publish('Hello, RabbitMQ!', 'myExchange'); } } ``` 上述代码定义了一个基于Yii2队列的作业类。在`execute`方法中,我们创建了一个生产者实例,并使用`publish`方法将消息发送到名为`myExchange`的交换机。 接下来,你可以使用Yii2队列组件将作业推送到RabbitMQ: ```php use yii\queue\Queue; /** @var Queue $queue */ $queue = Yii::$app->get('queue'); $queue->push(new MyJob()); ``` 以上代码创建了一个队列实例,并使用`push`方法将`MyJob`作业推送到队列中。 这只是一个简单的示例,你可以根据你的需求来扩展和定制。请参考yii2-rabbitmq扩展包的文档以获取更多详细信息和用法示例。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值