在CentOS系统中,使用PHP处理并发可以通过以下几种方法:
$pid = pcntl_fork(); if ($pid == -1) { die('could not fork'); } elseif ($pid) { // 父进程逻辑 pcntl_wait($status); // 等待子进程结束 } else { // 子进程逻辑 } 例如,使用Swoole:
$http = new Swoole\Http\Server("127.0.0.1", 9501); $http->on("start", function ($server) { echo "Swoole HTTP server is started at http://127.0.0.1:9501\n"; }); $http->on("request", function ($request, $response) { $response->header("Content-Type", "text/plain"); $response->end("Hello World\n"); }); $http->start(); 例如,使用RabbitMQ:
// 生产者 $connection = new AMQPStreamConnection('localhost', 5672, 'guest', 'guest'); $channel = $connection->channel(); $channel->queue_declare('task_queue', false, true, false, false); $msg = new AMQPMessage('Hello World!'); $channel->basic_publish($msg, '', 'task_queue'); echo " [x] Sent 'Hello World!'\n"; $channel->close(); $connection->close(); // 消费者 $connection = new AMQPStreamConnection('localhost', 5672, 'guest', 'guest'); $channel = $connection->channel(); $channel->queue_declare('task_queue', false, true, false, false); echo " [*] Waiting for messages in task_queue. To exit press CTRL+C\n"; $callback = function ($msg) { echo " [x] Received ", $msg->body, "\n"; }; $channel->basic_consume('task_queue', '', false, true, false, false, $callback); while ($channel->is_consuming()) { $channel->wait(); } $channel->close(); $connection->close(); 这些方法可以根据实际需求进行选择和组合,以实现高效的并发处理。