php三種實(shí)現(xiàn)多線程類似的方法
1、curl_multi方法
當(dāng)需要多線程的時(shí)候,可以用curl_multi一次性請求多個(gè)操作來完成,但curl走的是網(wǎng)絡(luò)通信,效率與可靠性就比較差了的。
function main(){ $sql = "select waybill_id,order_id from waybill where status>40 order by update_time desc limit 10 "; $data = Yii::app()->db->createCommand($sql)->queryAll(); //yii 框架格式 foreach ($data as $k => $v) { if ($k % 2 == 0) { //偶數(shù)發(fā)一個(gè)網(wǎng)址 $send_data[$k]['url'] = ''; $send_data[$k]['body'] = $v['waybill_id']; } else { //奇數(shù)發(fā)送另外一個(gè)網(wǎng)址 $send_data[$k]['url'] = 'http://www.abc.com'; $send_data[$k]['body']=array($v['order_id'] => array('extra' => 16)); } } $back_data =sendMulitRequest($send_data); var_dump($back_data); } function sendMulitRequest($send_data){ $params = array(); $curl = $text = array(); $handle = curl_multi_init(); foreach ($data as $k => $v) { if (empty($v['url'])) { $v['url'] = "http://www.xxx.com"; //if url is empty,set defalut url } $reqBody = json_encode($v['body']); $reqStream = array( 'body' => $reqBody, ); $encRequest = base64_encode(json_encode($reqStream)); $params['data'] = $encRequest; $curl[$k] = curl_init(); curl_setopt($curl[$k], CURLOPT_URL, $v['url']); curl_setopt($curl[$k], CURLOPT_POST, TRUE); curl_setopt($curl[$k], CURLOPT_HEADER, 0); curl_setopt($curl[$k], CURLOPT_POSTFIELDS, http_build_query($params)); curl_setopt($curl[$k], CURLOPT_RETURNTRANSFER, 1); curl_multi_add_handle($handle, $curl[$k]); } $active = null; do { $mrc = curl_multi_exec($handle, $active); } while ($mrc == CURLM_CALL_MULTI_PERFORM); while ($active && $mrc == CURLM_OK) { if (curl_multi_select($handle) != -1) { do { $mrc = curl_multi_exec($handle, $active); } while ($mrc == CURLM_CALL_MULTI_PERFORM); } } foreach ($curl as $k => $v) { if (curl_error($curl[$k]) == "") { $text[$k] = (string) curl_multi_getcontent($curl[$k]); } curl_multi_remove_handle($handle, $curl[$k]); curl_close($curl[$k]); } curl_multi_close($handle); return $text; }
2、通過stream_socket_client 方式
function sendStream() { $english_format_number = number_format($number, 4, '.', ''); echo $english_format_number; exit(); $timeout = 10; $result = array(); $sockets = array(); $convenient_read_block = 8192; $host = "test.local.com"; $sql = "select waybill_id,order_id from xm_waybill where status>40 order by update_time desc limit 1 "; $data = Yii::app()->db->createCommand($sql)->queryAll(); $id = 0; foreach ($data as $k => $v) { if ($k % 2 == 0) { $send_data[$k]['body'] = NoticeOrder::getSendData($v['waybill_id']); } else { $send_data[$k]['body'] = array($v['order_id'] => array('extra' => 16)); } $data = json_encode($send_data[$k]['body']); $s = stream_socket_client($host . ":80", $errno, $errstr, $timeout, STREAM_CLIENT_ASYNC_CONNECT | STREAM_CLIENT_CONNECT); if ($s) { $sockets[$id++] = $s; $http_message = "GET /php/test.php?data=" . $data . " HTTP/1.0\r\nHost:" . $host . "\r\n\r\n"; fwrite($s, $http_message); } else { echo "Stream " . $id . " failed to open correctly."; } } while (count($sockets)) { $read = $sockets; stream_select($read, $w = null, $e = null, $timeout); if (count($read)) { /* stream_select generally shuffles $read, so we need to compute from which socket(s) we're reading. */ foreach ($read as $r) { $id = array_search($r, $sockets); $data = fread($r, $convenient_read_block); if (strlen($data) == 0) { echo "Stream " . $id . " closes at " . date('h:i:s') . ".<br> "; fclose($r); unset($sockets[$id]); } else { $result[$id] = $data; } } } else { /* A time-out means that *all* streams have failed to receive a response. */ echo "Time-out!\n"; break; } } print_r($result); }
3、通過多進(jìn)程代替多線程
function daemon($func_name,$args,$number){ while(true){ $pid=pcntl_fork(); if($pid==-1){ echo "fork process fail"; exit(); }elseif($pid){//創(chuàng)建的子進(jìn)程 static $num=0; $num++; if($num>=$number){ //當(dāng)進(jìn)程數(shù)量達(dá)到一定數(shù)量時(shí)候,就對(duì)子進(jìn)程進(jìn)行回收。 pcntl_wait($status); $num--; } }else{ //為0 則代表是子進(jìn)程創(chuàng)建的,則直接進(jìn)入工作狀態(tài) if(function_exists($func_name)){ while (true) { $ppid=posix_getpid(); var_dump($ppid); call_user_func_array($func_name,$args); sleep(2); } }else{ echo "function is not exists"; } exit(); } } } function worker($args){ //do something } daemon('worker',array(1),2);
以上就是為大家分享的三種php實(shí)現(xiàn)多線程類似的方法,希望對(duì)大家的學(xué)習(xí)有所幫助。
- 使用pthreads實(shí)現(xiàn)真正的PHP多線程(需PHP5.3以上版本)
- php pthreads多線程的安裝與使用
- php使用pthreads v3多線程實(shí)現(xiàn)抓取新浪新聞信息操作示例
- PHP pthreads v3下同步處理synchronized用法示例
- PHP pthreads v3下的Volatile簡介與使用方法示例
- PHP pthreads v3使用中的一些坑和注意點(diǎn)分析
- 實(shí)現(xiàn)PHP多線程異步請求的3種方法
- 深入解析PHP中的(偽)多線程與多進(jìn)程
- PHP安裝threads多線程擴(kuò)展基礎(chǔ)教程
- PHP多線程批量采集下載美女圖片的實(shí)現(xiàn)代碼(續(xù))
- PHP pthreads v3下worker和pool的使用方法示例
相關(guān)文章
Ajax實(shí)現(xiàn)對(duì)靜態(tài)頁面的文章訪問統(tǒng)計(jì)功能示例
這篇文章主要介紹了Ajax實(shí)現(xiàn)對(duì)靜態(tài)頁面的文章訪問統(tǒng)計(jì)功能,結(jié)合簡單實(shí)例形式分析了靜態(tài)頁面實(shí)現(xiàn)訪問統(tǒng)計(jì)功能的計(jì)數(shù)操作相關(guān)技巧,需要的朋友可以參考下2016-10-10PHP字符串函數(shù)系列之nl2br(),在字符串中的每個(gè)新行 (\n) 之前插入 HTML 換行符br
nl2br() 函數(shù)在字符串中的每個(gè)新行 (\n) 之前插入 HTML 換行符 (br)。2011-11-11使用git遷移Laravel項(xiàng)目至新開發(fā)環(huán)境的步驟詳解
這篇文章主要介紹了遷移Laravel項(xiàng)目至新開發(fā)環(huán)境的步驟詳解,需要的朋友可以參考下2020-04-04