溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

PHP實現(xiàn)非阻塞批量推送數(shù)據(jù)的方法

發(fā)布時間:2020-05-29 11:46:55 來源:億速云 閱讀:894 作者:PHP專家 欄目:編程語言

PHP是一種通用開源腳本語言。語法吸收了C語言、Java和Perl的特點,利于學習,使用廣泛,主要適用于Web開發(fā)領(lǐng)域。PHP 獨特的語法混合了C、Java、Perl以及PHP自創(chuàng)的語法。它可以比CGI或者Perl更快速地執(zhí)行動態(tài)網(wǎng)頁。

今天看到論壇里面有人問PHP實現(xiàn)非阻塞批量推送數(shù)據(jù)的方法,這里大概總結(jié)下。

1、最簡單的辦法:

一個腳本同時跑多次,用參數(shù)來跑指定范圍。假如要推送10000用戶,可以每100個用戶運行一個腳本(腳本邏輯就是循環(huán)遍歷100個用戶,串行的發(fā)送數(shù)據(jù),代碼略),并且多個(100)腳本同時運行。

類似:

php task.php 1 100 &
php task.php 101 200 &
php task.php 201 300 &
........

當然這個方法不是非阻塞的,但是可以批量操作,大大加快處理速度。

2、麻煩點的:如果想要非阻塞并且是HTTP協(xié)議的話

可以用下面的代碼

<?php
// 創(chuàng)建一對cURL資源
$ch2 = curl_init();
$ch3 = curl_init();
 
// 設(shè)置URL和相應(yīng)的選項
curl_setopt($ch2, CURLOPT_URL, "http://baidu.com/");
curl_setopt($ch2, CURLOPT_HEADER, 0);
curl_setopt($ch3, CURLOPT_URL, "http://baidu.com/");
curl_setopt($ch3, CURLOPT_HEADER, 0);
 
// 創(chuàng)建批處理cURL句柄
$mh = curl_multi_init();
 
// 增加2個句柄
curl_multi_add_handle($mh,$ch2);
curl_multi_add_handle($mh,$ch3);
 
$active = null;
// 執(zhí)行批處理句柄
do {
    $mrc = curl_multi_exec($mh, $active);
} while ($mrc == CURLM_CALL_MULTI_PERFORM);
 
// 輪詢Server返回的結(jié)果
while ($active && $mrc == CURLM_OK) {
    if (curl_multi_select($mh) != -1) {
        do {
            $mrc = curl_multi_exec($mh, $active);
        } while ($mrc == CURLM_CALL_MULTI_PERFORM);
    }
}
 
// 匯總結(jié)果......
 
// 關(guān)閉全部句柄
curl_multi_remove_handle($mh, $ch2);
curl_multi_remove_handle($mh, $ch3);
curl_multi_close($mh);

3、非阻塞,并且不是HTTP協(xié)議的話,需要使用php的socket + stream_select

<?php
// uid數(shù)組,每個uid發(fā)送一個鏈接
$uids = array(1,2,3,4,5,6);
// 保存socket的數(shù)組
$sockets = array();
 
// 批量創(chuàng)建鏈接并發(fā)送數(shù)據(jù)
foreach($uids as $uid)
{
    // tcp://baidu.com 改成你要訪問的ip或者域名
    if(!$socket = stream_socket_client("tcp://baidu.com:80", $errno, $errstr))
    {
        echo "$errstr\n";
        continue;
    }
 
    // 根據(jù)自己的協(xié)議向服務(wù)端寫入數(shù)據(jù),這里模擬HTTP協(xié)議
    fwrite($socket, "GET / HTTP/1.1\r\nHost: www.baidu.com\r\n\r\n");
    // 設(shè)置成非阻塞
    stream_set_blocking($socket, 0);
    // 記錄數(shù)組
    $sockets[(int)$socket] = $socket;
}
 
// 批量等待數(shù)據(jù)返回
while(count($sockets)>0)
{
    $read = $sockets;
    $write = $e = array();
    // 等待數(shù)據(jù)可讀
    if(stream_select($read, $write, $e, 10))
    {
        // 循環(huán)讀數(shù)據(jù)
        foreach($read as $socket)
        {
           // 這里是服務(wù)端返回的數(shù)據(jù),需要的話可以循環(huán)讀
           echo fread($socket, 8192);
           // 數(shù)據(jù)讀取完畢關(guān)閉鏈接,并刪除鏈接
           fclose($socket);
           unset($sockets[(int)$socket]);
        }
    }
}

以上就是PHP實現(xiàn)非阻塞批量推送數(shù)據(jù)的方法的詳細內(nèi)容,更多請關(guān)注億速云其它相關(guān)文章!

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

php
AI