今天看到論壇裡面有人問如PHP何批量非阻塞向伺服器推送數據,這裡大概總結下。
相關推薦:《PHP教學》
1、最簡單的方法:
一個腳本同時跑多次,用參數來跑指定範圍。假如要推送10000用戶,可以每100個用戶運行一個腳本(腳本邏輯就是循環遍歷100個用戶,串行的發送數據,代碼略),並且多個(100)腳本同時運行。
類似:
php task.php 1 100 & php task.php 101 200 & php task.php 201 300 & ........
當然這個方法不是非阻塞的,但是可以批次操作,大大加快處理速度。
2、麻煩點的:如果想要非阻塞且是HTTP協定的話
可以用下面的程式碼
<?php // 创建一对cURL资源 $ch1 = curl_init(); $ch2 = curl_init(); // 设置URL和相应的选项 curl_setopt($ch1, CURLOPT_URL, "http://baidu.com/"); curl_setopt($ch1, CURLOPT_HEADER, 0); curl_setopt($ch2, CURLOPT_URL, "http://baidu.com/"); curl_setopt($ch2, CURLOPT_HEADER, 0); // 创建批处理cURL句柄 $mh = curl_multi_init(); // 增加2个句柄 curl_multi_add_handle($mh,$ch1); curl_multi_add_handle($mh,$ch2); $active = null; // 执行批处理句柄 do { $mrc = curl_multi_exec($mh, $active); } while ($mrc == CURLM_CALL_MULTI_PERFORM); // 轮询Server返回的结果 while ($active && $mrc == CURLM_OK) { if (curl_multi_select($mh) != -1) { do { $mrc = curl_multi_exec($mh, $active); } while ($mrc == CURLM_CALL_MULTI_PERFORM); } } // 汇总结果...... // 关闭全部句柄 curl_multi_remove_handle($mh, $ch1); curl_multi_remove_handle($mh, $ch2); curl_multi_close($mh);
3、非阻塞,並且不是HTTP協定的話,需要使用php的socket stream_select
<?php // uid数组,每个uid发送一个链接 $uids = array(1,2,3,4,5,6); // 保存socket的数组 $sockets = array(); // 批量创建链接并发送数据 foreach($uids as $uid) { // tcp://baidu.com 改成你要访问的ip或者域名 if(!$socket = stream_socket_client("tcp://baidu.com:80", $errno, $errstr)) { echo "$errstr\n"; continue; } // 根据自己的协议向服务端写入数据,这里模拟HTTP协议 fwrite($socket, "GET / HTTP/1.1\r\nHost: www.baidu.com\r\n\r\n"); // 设置成非阻塞 stream_set_blocking($socket, 0); // 记录数组 $sockets[(int)$socket] = $socket; } // 批量等待数据返回 while(count($sockets)>0) { $read = $sockets; $write = $e = array(); // 等待数据可读 if(stream_select($read, $write, $e, 10)) { // 循环读数据 foreach($read as $socket) { // 这里是服务端返回的数据,需要的话可以循环读 echo fread($socket, 8192); // 数据读取完毕关闭链接,并删除链接 fclose($socket); unset($sockets[(int)$socket]); } } }
以上是PHP非阻塞批次推送數據的詳細內容。更多資訊請關注PHP中文網其他相關文章!