在CentOS上使用PHP实现并发处理,可以采用以下几种方法:
PHP的pthreads扩展允许你在PHP中创建和管理线程。不过,这个扩展只支持CLI(命令行)模式,并且需要编译PHP时启用--enable-pthreads选项。
安装依赖:
sudo yum install php-devel gcc make
下载并编译PHP:
wget https://www.php.net/distributions/php-7.4.33.tar.gz
tar -zxvf php-7.4.33.tar.gz
cd php-7.4.33
./configure --enable-pthreads
make && sudo make install
启用pthreads:
编辑php.ini文件,添加以下行:
extension=pthreads.so
<?php
class MyThread extends Thread {
public function run() {
echo "Thread running\n";
}
}
$thread = new MyThread();
$thread->start();
$thread->join();
?>
ReactPHP是一个事件驱动的非阻塞I/O框架,适用于构建高性能的网络应用。
composer require react/react
<?php
require 'vendor/autoload.php';
$loop = React\EventLoop\Factory::create();
$server = new React\Http\Server($loop, function (Psr\Http\Message\ServerRequestInterface $request) {
return new React\Http\Response(
200,
['Content-Type' => 'text/plain'],
"Hello World\n"
);
});
$socket = new React\Socket\Server('127.0.0.1:8080', $loop);
$server->listen($socket);
echo 'Server running at http://127.0.0.1:8080\n';
$loop->run();
?>
消息队列是一种常见的并发处理方式,通过将任务放入队列中,由多个消费者并发处理。
sudo yum install rabbitmq-server
sudo systemctl start rabbitmq-server
sudo systemctl enable rabbitmq-server
<?php
require 'vendor/autoload.php';
use PhpAmqpLib\Connection\AMQPStreamConnection;
$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();
?>
消费者示例:
<?php
require 'vendor/autoload.php';
use PhpAmqpLib\Connection\AMQPStreamConnection;
$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";
sleep(substr_count($msg->body, '.'));
echo " [x] Done\n";
$msg->delivery_info['channel']->basic_ack($msg->delivery_info['delivery_tag']);
};
$channel->basic_qos(null, 1, null);
$channel->basic_consume('task_queue', '', false, false, false, false, $callback);
while ($channel->is_consuming()) {
$channel->wait();
}
$channel->close();
$connection->close();
?>
PHP的PCNTL扩展允许你创建和管理子进程。
sudo yum install php-pcntl
<?php
$pid = pcntl_fork();
if ($pid == -1) {
die('could not fork');
} elseif ($pid) {
// Parent
pcntl_wait($status); // Wait for child process to exit
} else {
// Child
echo "Child process running\n";
exit(0);
}
?>
选择哪种方法取决于你的具体需求和应用场景。对于简单的并发任务,消息队列可能是最简单和最有效的解决方案。对于需要更细粒度控制的场景,多线程或多进程可能更合适。异步编程则适用于构建高性能的网络应用。