Neo*_*ead 5 php codeigniter consumer php-amqplib
我对 RabbitMQ 还很陌生。我正在使用 codeigniter 来使用 php-amqplib 库,并且仍然想知道我所缺乏的一些知识。
$channel->wait()使用?就像在我的项目的一个用户想要向 100k 潜在客户广播新活动的情况下,如果第二个用户要发送大约 100 封邮件,那么第二个用户就会受到影响,第二个用户必须先等待 100k 邮件发送,然后是最后一个用户轮到他了。
我需要一个针对并发消费者的解决方案,使他们能够顺利工作而不影响其他人
这是我的代码片段:
public function campaign2(){
$this->load->library('mylibrary');
for( $i=1;$i<=5;$i++ ) {
$url = "http://localhost/myproject/rabbit/waiting";
$param = array('index' => $i);
$this->waiting($i);
}
}
public function waiting($i)
{
ini_set('memory_limit','400M');
ini_set('max_execution_time', 0);
ini_set('display_errors', 1);
${'conn_'.$i} = connectRabbit();
${'channel_'.$i} = ${'conn_'.$i}->channel();
${'channel_'.$i}->exchange_declare('ha-local-campaign-'.$i.'-exchange', 'fanout', false, true, false);
$q = populateQueueName('campaign-'.$i);
${'channel_'.$i}->queue_declare($q, false, true, false, false);
${'channel_'.$i}->queue_bind($q, 'ha-local-campaign-'.$i.'-exchange', 'priority.'.$i);
$consumer_tag = 'campaign_consumer' ;
function process_message($msg) {
echo 'Mail Sent';
$msg->delivery_info['channel']->basic_ack($msg->delivery_info['delivery_tag']);
}
function shutdown($channel, $conn){
echo '['.date('H:i:s').'] Campaign consumer - Shutdown!!';
}
${'channel_'.$i}->basic_consume($q, $consumer_tag, false, false, true, false,'process_message');
while(1) {
${'channel_'.$i}->wait();
}
register_shutdown_function('shutdown', ${'channel_'.$i}, ${'conn_'.$i});
}
Run Code Online (Sandbox Code Playgroud)
如果有人指导我完成整个过程,我将不胜感激。
当您致电时,$channel->wait()您是:
检查通道的队列以查看是否有待处理的消息。
对于每条消息,您将调用相应通道回调的已注册回调。
从“hello world示例”开始,一步一步::
// First, you define `$callback` as a function receiving
// one parameter (the _message_).
$callback = function($msg) {
echo " [x] Received ", $msg->body, "\n";
};
// Then, you assign `$callback` the the "hello" queue.
$channel->basic_consume('hello', '', false, true, false, false, $callback);
// Finally: While I have any callbacks defined for the channel,
while(count($channel->callbacks)) {
// inspect the queue and call the corresponding callbacks
//passing the message as a parameter
$channel->wait();
}
// This is an infinite loop: if there are any callbacks,
// it'll run forever unless you interrupt script's execution.
Run Code Online (Sandbox Code Playgroud)
让您的第二个用户发送使用不同的队列。您可以拥有任意数量的队列。
| 归档时间: |
|
| 查看次数: |
5383 次 |
| 最近记录: |