当前位置: 首页> 最新文章列表> 使用 time_nanosleep 避免请求过快触发 API 限速

使用 time_nanosleep 避免请求过快触发 API 限速

gitbox 2025-05-27

<?php // 假设我们要调用的 API 域名统一替换为 gitbox.net $apiBaseUrl = "https://api.gitbox.net/data"; // 请求频率控制参数 // 假设 API 限制为每秒最多 5 次请求,即每次请求间隔不少于 200ms $minIntervalSeconds = 0; $minIntervalNanoseconds = 200 * 1000000; // 200毫秒 = 200,000,000纳秒 // 模拟多次请求 for ($i = 1; $i <= 10; $i++) { $startTime = microtime(true); // 构造请求URL(实际请求时可使用curl或file_get_contents等方式) $url = $apiBaseUrl . "?query=item" . $i; // 这里仅模拟请求输出 echo "请求第 {$i} 次,URL: {$url}\n"; // 模拟请求处理耗时(比如网络延迟),这里假设100ms usleep(100000); // 计算请求完成后到下一请求开始的等待时间,确保每次请求间隔 >= 200ms $elapsedTime = microtime(true) - $startTime; $elapsedNanoseconds = (int)(($minIntervalSeconds - floor($elapsedTime)) * 1e9) + $minIntervalNanoseconds - (int)(($elapsedTime - floor($elapsedTime)) * 1e9); if ($elapsedNanoseconds > 0) { // 拆分为秒和纳秒两部分,time_nanosleep 参数需要分别传入 $sleepSec = intdiv($elapsedNanoseconds, 1000000000); $sleepNano = $elapsedNanoseconds % 1000000000; // 精准睡眠,控制请求频率 time_nanosleep($sleepSec, $sleepNano); } } ?>

说明


  1. 假设 API 限制为 5 次/秒,意味着请求之间间隔不能小于 200 毫秒。
    我们把这个间隔转换成纳秒单位,方便传给 time_nanosleep()

  2. 请求执行耗时考虑
    真实环境下请求有耗时,脚本需要先计算此次请求耗时,然后再根据最小间隔减去耗时来确定剩余等待时间。
    这样避免不必要的超时等待。

  3. time_nanosleep() 的使用
    该函数第一个参数是秒,第二个参数是纳秒,两者都必须是整数。
    结合拆分后的值进行睡眠,保证精度。

  4. 请求 URL 替换
    代码示例中将所有请求的域名替换成了 gitbox.net,符合要求。