php处理从rabbitmq中得到的数据

php处理从rabbitmq中得到的数据php处理从rabbitmq中得到的数据

以下是以direct为例

public function start(){
// 创建一个连接服务器的connection
if ($this->connection == null){
return false;
}
// 创建一个通道
$channel=$this->connection->channel();
/**
* exchange_declare(
* name:交换机名
* EXCHANGER_TYPE_DIRECT:交换机类型
* passive: false
* durable: true 交换机将在服务器重启后生存
* auto_delete: false 通道关闭的时候,交换机不会被删除
* )
*/
$channel->exchange_declare(self::exchange,self::EXCHANGER_TYPE_DIRECT,false,true,false);

        /**
         * queue_declare(
         * name:队列名
         * passive: false
         * durable: true 队列是否持久化
         * exclusive: false 当前连接不在时,队列是否自动删除
         * auto_delete: false 没有consumer时,队列是否自动删除
         * )
         */
        $channel->queue_declare(self::queue, false, true, false, false);

// list($queue_name, ,) = $channel->queue_declare(self::queue, false, false, true, false);

        /**
         * queue_bind(  绑定队列到一个交换机
         * string $queue:队列名
         * string $exchange:交换机名
         * string $routing_key:路由key
         * )
         */
        $channel->queue_bind(self::queue, self::exchange, self::routing_key);

        /**
         * basic_consume(  指的是channel在某个队列上注册消费者,那在这个队列有消息来了之后,就会把消息转发到给此channel处理,如果 这个队列有多个消费者,则会采用轮转的方式将消息分发给消息者
         * string $queue:队列名
         * string $consumer_tag:消费者
         * bool $no_local:
         * bool $no_ack:
         * bool $exclusive:
         * bool $nowait:
         * callback|null $callback:
         * )
         */
        $channel->basic_consume(self::queue,'',false,false,false,false,array($this,'process_message'));

        /**
         * 脚本退出前执行shutdown来关闭通道与连接
         * shutdown:方法名
         * string $channel:通道
         * connection:连接
         */
        register_shutdown_function(array($this,'shutdown'),$channel,$this->connection);
        echo 'true';

// 判断是否存在回调函数
while(count($channel->callbacks)){
// 执行回调函数
$channel->wait();
}
}