Swoole多进程结合RabbitMq使用

<?php
require_once __DIR__ . '/lib/rabbitmq/rabbitmq.php';
require_once __DIR__ . '/lib/general/general.php';

define('RUNENV', getenv('ENV') ? getenv('ENV') : 'local');

$url = 'https://local.banggood.com/?com=test&t=getShipment';    //业务操作接口

$workerNum = $argv[1] ?: 1;    //设置swoole工作进程池的数量,工作进程的数量(当一个进程退出后,Pool会及时拉取另一个进程进行补充)
$pool = new Swoole\Process\Pool($workerNum);
$pool->on('WorkerStart', function ($pool, $workerId) use ($url) {    //子进程启动,回调函数
    //**************************业务操作处理****************************
    try {
        $zmq = new ZRabbitmq(RUNENV);    //实例一个mq   
        $zmq->setChannel()    // 建立连接
            ->setExchange('bg_shipment_channel_limit_batch')    //设置交换机
            ->setQueue('bg_shipment_channel_limit_batch', AMQP_DURABLE);    //设置队列
        $zmq->consume(function ($msg) use ($url,$zmq) {    //消费bg_shipment_channel_limit_batch队列
            $data = json_decode($msg,true);    //解析$msg(队列中取得的数据)
            $url.='&token=27b60a7c267cb2fb75017eaa2afa3460&id='.(int)$data['id'].'&tag_ids='.json_encode($data['tag_ids'])
                .'&key='.$data['key'].'&last='.$data['last'].'&is_batch='.$data['is_batch'];    //把数据凭借到接口url
            ZGeneral::curlGet($url, '', 300, $httpCode);    //把队列中的数据,逐个请求到指定业务操作的接口(包含sql操作,redis操作等等)

            if($httpCode != 200){
                //此处可加上,记录接口请求失败的错误日志逻辑
            }
            $ret = $httpCode == 200 ? true : false;
            return $ret;
        }, 1);
    } catch (AMQPQueueException $ex) {
        $errorMsg = $ex->getMessage();    //mq抛出异常
    } catch (Exception $ex) {
        $errorMsg = $ex->getMessage();    //php抛出异常
    }

    if($errorMsg){
         //此处可加上,记录接口请求失败的错误日志逻辑
    }
});

$pool->start();    //启动swoole工作进程

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
A: 首先,需要安装 `php-amqplib/php-amqplib` 和 `swoole/amqp` 扩展。 1. 引入依赖 ```php use PhpAmqpLib\Connection\AMQPStreamConnection; use PhpAmqpLib\Message\AMQPMessage; use Swoole\Coroutine\AMQP\Connection; use Swoole\Coroutine\AMQP\Channel; ``` 2. 创建 RabbitMQ 连接和通道 ```php $connection = new AMQPStreamConnection('localhost', 5672, 'guest', 'guest'); $channel = $connection->channel(); ``` 3. 创建 Swoole AMQP 连接和通道 ```php $swooleConnection = new Connection([ 'host' => 'localhost', 'port' => 5672, 'login' => 'guest', 'password' => 'guest', ]); $swooleChannel = new Channel($swooleConnection); ``` 4. 发布消息到 RabbitMQ ```php $message = new AMQPMessage('Hello, world!'); $channel->basic_publish($message, '', 'queue-name'); ``` 5. 发布消息到 Swoole AMQP ```php $message = new AMQPMessage('Hello, world!'); $swooleChannel->basic_publish($message, '', 'queue-name'); ``` 6. 消费消息 可以通过 `basic_consume` 方法设置回调函数来消费消息。在回调函数中,可以通过 Swoole AMQP 的 `wait` 方法等待消费者确认。 ```php $callback = function ($message) use ($swooleChannel) { echo "Received message: ", $message->body, "\n"; $swooleChannel->ack($message->delivery_info['delivery_tag']); }; $channel->basic_consume('queue-name', '', false, true, false, false, $callback); while (count($channel->callbacks)) { $channel->wait(); } ``` 7. 关闭连接 ```php $channel->close(); $connection->close(); $swooleChannel->close(); $swooleConnection->close(); ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值