rabbitmq direct 模式

1.product 

channel();
$channel->exchange_declare($exchange,'direct',false,false,false);
for($i=0;$i<100;$i++) {
    $data= array('name'=>'zyw'.$i,'time'=>time(),'i'=>$i);
    $msg = new AMQPMessage(json_encode($data));
    $channel->basic_publish($msg,$exchange,'direct');
}
$channel->close();
$connection->close();

2.consume

channel();
$channel->exchange_declare($exchange,'direct',false,false,false);
$queue_name='direct';
$channel->queue_declare($queue_name, false, false, true, false);

$channel->queue_bind($queue_name, $exchange, 'direct');
echo " [*] Waiting for logs. To exit press CTRL+C\n";

$callback = function ($msg) {
    echo ' [x] ', $msg->delivery_info['routing_key'], ':', $msg->body, "\n";
   $msg->delivery_info['channel']->basic_ack($msg->delivery_info['delivery_tag']);
};

$channel->basic_consume($queue_name, '', false, false, false, false, $callback);

while ($channel->is_consuming()) {
    $channel->wait();
}

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

 

你可能感兴趣的:(服务器搭建)