美文网首页
php实现并发

php实现并发

作者: 云龙789 | 来源:发表于2020-02-04 16:00 被阅读0次

使用场景

如果你第三方的多个接口,需要循环请求,这时候就需要并发处理,因为 php 是单进程,顺序执行的程序,如果有一个接口挂了,那么后面的接口也不能得到请求,或者某个接口等待时间过长,下面的接口也需要等待时间,那么十多个接口每个接口等待1S,十个接口就需要10S才能完成一次请求。这时候,就需要使用并发请求

使用方案

可以先写好针对某个第三方的请求接口,然后使用并发请求这些第三方的接口

并发代码

function request(){
$srart_time = microtime(TRUE);
$webSiteUrl = 'http://test/';
/**
 * 结算
 */
$alls = [
    $webSiteUrl . "1.php",
    $webSiteUrl . "2.php",
];

//1 创建批处理cURL句柄
$chHandle = curl_multi_init();
$chArr = [];
//2.创建多个cURL资源
foreach ($alls as $Url) {
    $chArr[$Url] = curl_init();
    curl_setopt($chArr[$Url], CURLOPT_URL, $Url);
    curl_setopt($chArr[$Url], CURLOPT_RETURNTRANSFER, 1);
    curl_setopt($chArr[$Url], CURLOPT_TIMEOUT, 1);
    curl_multi_add_handle($chHandle, $chArr[$Url]); //2 增加句柄
}

$active = null;

/**常量
 * CURLM_CALL_MULTI_PERFORM==-1
 * // CURLM_OK == 0
 **/

do {
    $mrc = curl_multi_exec($chHandle, $active); //3 执行批处理句柄
} while ($mrc == CURLM_CALL_MULTI_PERFORM); //4

//4 $active 为true,即$chHandle批处理之中还有$ch句柄正待处理,$mrc==CURLM_OK,即上一次$ch句柄的读取或写入已经执行完毕。
while ($active && $mrc == CURLM_OK) {
    if (curl_multi_select($chHandle) != CURLM_CALL_MULTI_PERFORM) {//$chHandle批处理中还有可执行的$ch句柄,curl_multi_select($chHandle) != -1程序退出阻塞状态。
        do {
            $mrc = curl_multi_exec($chHandle, $active);//继续执行需要处理的$ch句柄。
        } while ($mrc == CURLM_CALL_MULTI_PERFORM);
    }
}

foreach ($chArr as $k => $ch) {
//    $result[$k] = curl_multi_getcontent($ch); //5 获取句柄的返回值,不需要
    curl_multi_remove_handle($chHandle, $ch);//6 将$chHandle中的句柄移除
}
curl_multi_close($chHandle); //7 关闭全部句柄
$end_time = microtime(TRUE);
echo sprintf("use time:%.3f s", $end_time - $srart_time);
}

php 实现循环请求接口

这种情况针对的是循环需要在1S内执行的程序,如果执行频率超过1S,则直接使用linux 的计划任务即可

// 无时间限制执行此程序
set_time_limit(0);
// 设置默认时区  北京时间
date_default_timezone_set('PRC');

do {
    //  如果不存在 stop  文件,则程序停止 并且记录停止时间
    if (!file_exists(dirname(__FILE__) . '/stop')) {
        $handle = fopen('./ceshi.log', 'a+');
        fwrite($handle, '程序停止时间: ' . date('Y-m-d H:i:s') . "\n");
        fclose($handle);
        exit();
    }
    sleep(4);
    try {
        requestNewOpen();
    } catch (Exception $exception) {
        $handle = fopen('./ceshi.log', 'a+');
        fwrite($handle, 'catch : ' . $exception->getMessage() . "\n");
        fclose($handle);
    }
} while (true);


相关文章

  • php实现并发

    相关 使用PHP代码实现计划任务 使用场景 如果你第三方的多个接口,需要循环请求,这时候就需要并发处理,因为 ph...

  • 秒杀系统开发(一)

    本文部分内容来自 【PHP秒杀系统 高并发高性能的极致挑战】 目标 如何设计和实现秒杀系统? 实现系统的高并发、高...

  • Java与线程

    并发不一定要依赖多线程(如PHP的多进程并发),但在Java中谈论并发,大多数都与线程脱不开关系 线程的实现 线程...

  • PHP 并发 IO 编程之路

    PHP 并发 IO 编程之路

  • PHP实现高并发服务器

    没图、直接上正文 一提到高并发,就没有办法绕开I/O复用,再具体到特定的平台linux, 就没办法绕开epoll....

  • MySQL系列之三 -- -并发(MVCC)

    MySQL 并发控制如何实现 MySQL 如何实现高并发? 一 并发控制 抛开MySQL,通过技术上来讨论并发控制...

  • nginx|Yii2.0路由管理实现版本控制

    由于公司并发上来了,改基础的项目的架构, 由nginx+apache+php改成nginx+php-fpm+php...

  • 5. LAMP架构进阶

    4 php-fpm 模式实现LAMP 4.1 实现php-fpm(PHP FastCGI Proces Manag...

  • PHP 高并发之 php+go 实现 actor 模型

    传统的php代码,调用memcache api,mysql api都会被阻塞住,这是影响并发的一个瓶颈,而且 ph...

  • go语言并发操作

    go语言实现并发 通过go 实现并发操作 执行上述代码,会间隔执行say方法 通过channel实现并发数据间的通...

网友评论

      本文标题:php实现并发

      本文链接:https://www.haomeiwen.com/subject/fwwrxhtx.html