PHP多線程之內(nèi)部多線程實例分析
更新時間:2015年03月09日 10:00:55 作者:瘋狂的流浪
這篇文章主要介紹了PHP多線程之內(nèi)部多線程,實例分析了php多線程的使用技巧,具有一定參考借鑒價值,需要的朋友可以參考下
本文實例分析了PHP多線程之內(nèi)部多線程用法。分享給大家供大家參考。具體如下:
復制代碼 代碼如下:
<?php
class Http_MultiRequest
{
//要并行抓取的url 列表
private $urls = array();
//curl 的選項
private $options;
//構(gòu)造函數(shù)
function __construct($options = array())
{
$this->setOptions($options);
}
//設置url 列表
function setUrls($urls)
{
$this->urls = $urls;
return $this;
}
//設置選項
function setOptions($options)
{
$options[CURLOPT_RETURNTRANSFER] = 1;
if (isset($options['HTTP_POST']))
{
curl_setopt($ch, CURLOPT_POST, 1);
curl_setopt($ch, CURLOPT_POSTFIELDS, $options['HTTP_POST']);
unset($options['HTTP_POST']);
}
if (!isset($options[CURLOPT_USERAGENT]))
{
$options[CURLOPT_USERAGENT] = 'Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1; SV1;)';
}
if (!isset($options[CURLOPT_FOLLOWLOCATION]))
{
$options[CURLOPT_FOLLOWLOCATION] = 1;
}
if (!isset($options[CURLOPT_HEADER]))
{
$options[CURLOPT_HEADER] = 0;
}
$this->options = $options;
}
//并行抓取所有的內(nèi)容
function exec()
{
if(empty($this->urls) || !is_array($this->urls))
{
return false;
}
$curl = $data = array();
$mh = curl_multi_init();
foreach($this->urls as $k => $v)
{
$curl[$k] = $this->addHandle($mh, $v);
}
$this->execMulitHandle($mh);
foreach($this->urls as $k => $v)
{
$data[$k] = curl_multi_getcontent($curl[$k]);
curl_multi_remove_handle($mh, $curl[$k]);
}
curl_multi_close($mh);
return $data;
}
//只抓取一個網(wǎng)頁的內(nèi)容。
function execOne($url)
{
if (empty($url)) {
return false;
}
$ch = curl_init($url);
$this->setOneOption($ch);
$content = curl_exec($ch);
curl_close($ch);
return $content;
}
//內(nèi)部函數(shù),設置某個handle 的選項
private function setOneOption($ch)
{
curl_setopt_array($ch, $this->options);
}
//添加一個新的并行抓取 handle
private function addHandle($mh, $url)
{
$ch = curl_init($url);
$this->setOneOption($ch);
curl_multi_add_handle($mh, $ch);
return $ch;
}
//并行執(zhí)行(這樣的寫法是一個常見的錯誤,我這里還是采用這樣的寫法,這個寫法
//下載一個小文件都可能導致cup占用100%, 并且,這個循環(huán)會運行10萬次以上
//這是一個典型的不懂原理產(chǎn)生的錯誤。這個錯誤在PHP官方的文檔上都相當?shù)某R?。?br /> private function execMulitHandle($mh)
{
$running = null;
do {
curl_multi_exec($mh, $running);
} while ($running > 0);
}
}
/*下面是上面的類的一個測試的例子:*/
$urls = array("http://baidu.com", "http://baidu.com", "http://baidu.com", "http://baidu.com", "http://baidu.com", "http://baidu.com", "http://www.google.com", "http://www.sina.com.cn", );
$m = new Http_MultiRequest();
$t = microtime(true);
$m->setUrls($urls);
//parallel fetch(并行抓?。?
$data = $m->exec();
$parallel_time = microtime(true) - $t;
echo $parallel_time . "\n";
$t = microtime(true);
//serial fetch(串行抓取):
foreach ($urls as $url)
{
$data[] = $m->execOne($url);
}
$serial_time = microtime(true) - $t;
echo $serial_time . "\n";
class Http_MultiRequest
{
//要并行抓取的url 列表
private $urls = array();
//curl 的選項
private $options;
//構(gòu)造函數(shù)
function __construct($options = array())
{
$this->setOptions($options);
}
//設置url 列表
function setUrls($urls)
{
$this->urls = $urls;
return $this;
}
//設置選項
function setOptions($options)
{
$options[CURLOPT_RETURNTRANSFER] = 1;
if (isset($options['HTTP_POST']))
{
curl_setopt($ch, CURLOPT_POST, 1);
curl_setopt($ch, CURLOPT_POSTFIELDS, $options['HTTP_POST']);
unset($options['HTTP_POST']);
}
if (!isset($options[CURLOPT_USERAGENT]))
{
$options[CURLOPT_USERAGENT] = 'Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1; SV1;)';
}
if (!isset($options[CURLOPT_FOLLOWLOCATION]))
{
$options[CURLOPT_FOLLOWLOCATION] = 1;
}
if (!isset($options[CURLOPT_HEADER]))
{
$options[CURLOPT_HEADER] = 0;
}
$this->options = $options;
}
//并行抓取所有的內(nèi)容
function exec()
{
if(empty($this->urls) || !is_array($this->urls))
{
return false;
}
$curl = $data = array();
$mh = curl_multi_init();
foreach($this->urls as $k => $v)
{
$curl[$k] = $this->addHandle($mh, $v);
}
$this->execMulitHandle($mh);
foreach($this->urls as $k => $v)
{
$data[$k] = curl_multi_getcontent($curl[$k]);
curl_multi_remove_handle($mh, $curl[$k]);
}
curl_multi_close($mh);
return $data;
}
//只抓取一個網(wǎng)頁的內(nèi)容。
function execOne($url)
{
if (empty($url)) {
return false;
}
$ch = curl_init($url);
$this->setOneOption($ch);
$content = curl_exec($ch);
curl_close($ch);
return $content;
}
//內(nèi)部函數(shù),設置某個handle 的選項
private function setOneOption($ch)
{
curl_setopt_array($ch, $this->options);
}
//添加一個新的并行抓取 handle
private function addHandle($mh, $url)
{
$ch = curl_init($url);
$this->setOneOption($ch);
curl_multi_add_handle($mh, $ch);
return $ch;
}
//并行執(zhí)行(這樣的寫法是一個常見的錯誤,我這里還是采用這樣的寫法,這個寫法
//下載一個小文件都可能導致cup占用100%, 并且,這個循環(huán)會運行10萬次以上
//這是一個典型的不懂原理產(chǎn)生的錯誤。這個錯誤在PHP官方的文檔上都相當?shù)某R?。?br /> private function execMulitHandle($mh)
{
$running = null;
do {
curl_multi_exec($mh, $running);
} while ($running > 0);
}
}
/*下面是上面的類的一個測試的例子:*/
$urls = array("http://baidu.com", "http://baidu.com", "http://baidu.com", "http://baidu.com", "http://baidu.com", "http://baidu.com", "http://www.google.com", "http://www.sina.com.cn", );
$m = new Http_MultiRequest();
$t = microtime(true);
$m->setUrls($urls);
//parallel fetch(并行抓?。?
$data = $m->exec();
$parallel_time = microtime(true) - $t;
echo $parallel_time . "\n";
$t = microtime(true);
//serial fetch(串行抓取):
foreach ($urls as $url)
{
$data[] = $m->execOne($url);
}
$serial_time = microtime(true) - $t;
echo $serial_time . "\n";
希望本文所述對大家的php程序設計有所幫助。
您可能感興趣的文章:
- php 多線程上下文中安全寫文件實現(xiàn)代碼
- PHP多線程抓取網(wǎng)頁實現(xiàn)代碼
- 深入解析PHP中的(偽)多線程與多進程
- 實現(xiàn)PHP多線程異步請求的3種方法
- php fsockopen解決辦法 php實現(xiàn)多線程
- PHP使用CURL_MULTI實現(xiàn)多線程采集的例子
- php異步多線程swoole用法實例
- PHP多線程類及用法實例
- PHP多線程編程之管道通信實例分析
- PHP使用CURL實現(xiàn)多線程抓取網(wǎng)頁
- PHP CURL 多線程操作代碼實例
- PHP+shell實現(xiàn)多線程的方法
- php結(jié)合curl實現(xiàn)多線程抓取
- 如何解決PHP無法實現(xiàn)多線程的問題
相關文章
Linux環(huán)境下搭建php開發(fā)環(huán)境的操作步驟
本篇文章是對Linux環(huán)境下搭建php開發(fā)環(huán)境的操作步驟進行了詳細的分析介紹,需要的朋友參考下2013-06-06PHP計劃任務、定時執(zhí)行任務的實現(xiàn)代碼
PHP計劃任務、定時執(zhí)行任務的實現(xiàn)用到的函數(shù) ignore_user_abort(),set_time_limit(0),sleep($interval) 此代碼只要運行一次后關閉瀏覽器即可。2011-04-04PHP計算數(shù)組中值的和與乘積的方法(array_sum與array_product函數(shù))
這篇文章主要介紹了PHP計算數(shù)組中值的和與乘積的方法,結(jié)合實例形式較為詳細的分析了array_sum與array_product函數(shù)的功能與使用方法,需要的朋友可以參考下2016-04-04PHP中執(zhí)行MYSQL事務解決數(shù)據(jù)寫入不完整等情況
事務可以進行模擬SQL操作,當所有的SQL都操作成功的時候才進行SQL操作,只要有一個操作失敗就回滾當前事務的所有SQL操作,避免出現(xiàn)上面描述中出現(xiàn)的數(shù)據(jù)寫入不完整等情況2014-01-01php模擬post行為代碼總結(jié)(POST方式不是絕對安全)
GET行為比較簡單,POST比較復雜一些2012-02-02php 判斷頁面或圖片是否經(jīng)過gzip壓縮的方法
下面小編就為大家?guī)硪黄猵hp 判斷頁面或圖片是否經(jīng)過gzip壓縮的方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-04-04