PHP多進程同步下載圖片的實現方法,pcntl_fork教程

來源:互聯網
上載者:User

pcntl_fork()函數建立一個子進程,這個子進程僅PID(進程號) 和PPID(父進程號)與其父進程不同。fork怎樣在您的系統工作的詳細資料請查閱您的系統 的fork(2)手冊。

注意:PHP有個pcntl_fork的函數可以實現多進程,但要載入pcntl拓展,而且只有在linux下才能編譯這個拓展.

1.首先在ubuntu下編譯pcntl.so,我的ubuntu下找不到pcntl的包,於是建立一個檔案夾下載了整個PHP包,在裡面找到了pcntl包運行如下命令,代碼如下:

 

 代碼如下 複製代碼
# mkdir php
# cd php
# apt-get source php5
# cd php5-(WHATEVER_RELEASE)/ext/pcntl
# phpize
# ./configure (注一)
# make
# make install phpize 命令是用來準備 PHP 外掛模組的編譯環境的

 

成功的安裝將建立 extname.so 並放置於 PHP 的外掛模組目錄中(預設存放於 /usr/lib/php/modules/ 內),需要調整 php.ini,加入 extension=extname.so 這一行之後才能使用此外掛模組.

 代碼如下 複製代碼
void pcntl_exec(string $path [,array $args [,array $envs ]])

pcntl_exec — 在當前進程空間執行指定程式,代碼如下:

$cmds=array(
        array('/home/jerry/projects/www/test2.php'),
        array('/home/jerry/projects/www/test3.php')
);
 
foreach($cmds as $cmd){
        $pid=pcntl_fork();
        if($pid==-1){
        //進程建立失敗
            echo '建立子進程失敗時返回-1';
            exit(-1);
        }
        else if($pid){
        //父進程會得到子進程號,所以這裡是父進程執行的邏輯
            pcntl_wait($status,WNOHANG);
        }
        else{
        //子進程處理邏輯
            sleep(5);
            pcntl_exec('/usr/bin/php',$cmd);
            exit(0);
        }
}

 

例,執行個體多圖片同步下載,代碼如下:

 

 代碼如下 複製代碼
#!/usr/bin/php
<?php
// 需要抓取的網頁地址
$url = 'http://www.jb51.net';
$content = file_get_contents($url);
preg_match_all('/<imgs+src="(.*?)"/', $content, $matches,PREG_SET_ORDER);
echo "已發現".count($matches)."張圖片n";
 
list($sm, $ss) = explode(" ", microtime());
foreach ($matches as $k => $val)
{
 $pid[$k] = pcntl_fork();
 if(!$pid[$k])
 {
  download($url, $val);
  // 子進程要exit否則會進行遞迴多進程,父進程不要exit否則終止多進程
  exit(0);
 }
 
 if ($pid[$k])
 {
//    pcntl_waitpid($pid[$k], $status, WUNTRACED);
 }
 
}
echo "下載完成n";
 
list($em, $es) = explode(" ", microtime());
 
echo "用時:",($es+$em) - ($ss + $sm),"n";
/**
 * 抓取網頁圖片
 * 
 */
function download($url, $val)
{
 $pic_url = $val[1];
 if (strpos($val[1], '//') !== false)
 {
  ;
 }
 elseif (preg_match('@^(.*?)/@', $val[1], $inner_matches) == 0)
 {
  $pic_url = $url.$val[1];
 }
 elseif (preg_match('@[:.]@', $inner_matches[1], $tmp_matches) == 0)
 {
  $pic_url = $url.$val[1];
 }
 
 $pic = file_get_contents($pic_url);
 
 if ($pic === false)
 {
  return;
 }
 
 preg_match('@/([^/]+)$@', $pic_url, $tmp_matches);
 // 可使用assert處理異常
 $pic_file_name = $tmp_matches[1];
 $f = fopen("tmp/".$pic_file_name, "wb"); #
 fwrite($f, $pic);
 fclose($f);
}
 
/* End of file pcntl_fork.php */
?>

 

多進程同步下載圖片是一個非常有用的技術,希望本教程對你有所協助。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.