在共享主机环境下,php 脚本执行时间受限(如 120 秒),若循环内连续发起耗时较长的 curl post 请求,总执行时间会累加而非并行,极易触发“maximum execution time exceeded”致命错误。本文提供优化方案与关键实践建议。
你遇到的问题本质是同步阻塞式请求的累积耗时超限,而非单次请求超时。虽然每次 curl_exec() 是独立 HTTP 请求,但 PHP 脚本本身是单线程顺序执行的:第一个请求耗时 32 秒、第二个 50 秒,仅两次循环就已占用 82 秒;当循环扩大(如 i
你的原始代码存在两个关键隐患:
✅ 推荐解决方案如下:
在循环内插入 sleep(1) 是快速缓解策略,可显著降低服务端压力与连接竞争:
for ($i = 0; $i <= 200; $i += 100) {
$postData = [
'start' => $i,
'end' => $i + 100
];
$ch = curl_init('https://your-server.com/endpoint');
curl_setopt_array($ch, [
CURLOPT_POST => TRUE,
CURLOPT_RETURNTRANSFER => TRUE,
CURLOPT_TIMEOUT => 60, // 单次请求最长等待 60 秒
CURLOPT_CONNECTTIMEOUT => 10, // 连接阶段超时 10 秒
CURLOPT_HTTPHEADER => ['Content-Type: application/json'],
CURLOPT_POSTFIELDS => json_encode($postData)
]);
$response = curl_exec($ch);
if ($response === false) {
error_log('cURL Error: ' . curl_error($ch));
continue;
}
$responseData = json_decode($response, true);
echo $response . "\n";
curl_close($ch);
sleep(1); // ⚠️ 关键:强制间隔 1 秒,避免请求洪峰
}若业务允许,应彻底规避「前端浏览器直触长耗时任务」模式:
通过合理控制请求节奏 + 显式超时 + 架构升级,即可在资源受限环境中稳定完成批量数据提交任务。