真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

php利用線程操作大數(shù)據(jù),php多線程

php\同一個(gè)文件怎么使用 多線程處理

如果你是Linux下執(zhí)行的PHP

在新化等地區(qū),都構(gòu)建了全面的區(qū)域性戰(zhàn)略布局,加強(qiáng)發(fā)展的系統(tǒng)性、市場(chǎng)前瞻性、產(chǎn)品創(chuàng)新能力,以專注、極致的服務(wù)理念,為客戶提供做網(wǎng)站、網(wǎng)站設(shè)計(jì) 網(wǎng)站設(shè)計(jì)制作按需求定制開發(fā),公司網(wǎng)站建設(shè),企業(yè)網(wǎng)站建設(shè),高端網(wǎng)站設(shè)計(jì),全網(wǎng)整合營(yíng)銷推廣,外貿(mào)網(wǎng)站制作,新化網(wǎng)站建設(shè)費(fèi)用合理。

你看看手冊(cè)的pcntl_fork pcntl_wait 函數(shù)

如果是windows,沒辦法

pcntl_fork(PHP 4 = 4.1.0, PHP 5)pcntl_fork — 在當(dāng)前進(jìn)程當(dāng)前位置產(chǎn)生分支(子進(jìn)程)。譯注:fork是創(chuàng)建了一個(gè)子進(jìn)程,父進(jìn)程和子進(jìn)程 都從fork的位置開始向下繼續(xù)執(zhí)行,不同的是父進(jìn)程執(zhí)行過程中,得到的fork返回值為子進(jìn)程 號(hào),而子進(jìn)程得到的是0。

說明int pcntl_fork ( void )pcntl_fork()函數(shù)創(chuàng)建一個(gè)子進(jìn)程,這個(gè)子進(jìn)程僅PID(進(jìn)程號(hào)) 和PPID(父進(jìn)程號(hào))與其父進(jìn)程不同。fork怎樣在您的系統(tǒng)工作的詳細(xì)信息請(qǐng)查閱您的系統(tǒng) 的fork(2)手冊(cè)。

返回值成功時(shí),在父進(jìn)程執(zhí)行線程內(nèi)返回產(chǎn)生的子進(jìn)程的PID,在子進(jìn)程執(zhí)行線程內(nèi)返回0。失敗時(shí),在 父進(jìn)程上下文返回-1,不會(huì)創(chuàng)建子進(jìn)程,并且會(huì)引發(fā)一個(gè)PHP錯(cuò)誤。

范例Example #1 pcntl_fork() 示例

?php

$pid = pcntl_fork();

//父進(jìn)程和子進(jìn)程都會(huì)執(zhí)行下面代碼

if ($pid == -1) {

//錯(cuò)誤處理:創(chuàng)建子進(jìn)程失敗時(shí)返回-1.

die('could not fork');

} else if ($pid) {

//父進(jìn)程會(huì)得到子進(jìn)程號(hào),所以這里是父進(jìn)程執(zhí)行的邏輯

pcntl_wait($status); //等待子進(jìn)程中斷,防止子進(jìn)程成為僵尸進(jìn)程。

} else {

//子進(jìn)程得到的$pid為0, 所以這里是子進(jìn)程執(zhí)行的邏輯。

}

?

PHP是單線程的,如何應(yīng)對(duì)大量的http訪問

進(jìn)程是操作系統(tǒng)分配資源和調(diào)度的功能單元,一個(gè)進(jìn)程里面有一個(gè)或者多個(gè)線程,線程是操作系統(tǒng)的一個(gè)獨(dú)立運(yùn)算單元。通常可以認(rèn)為一個(gè)軟件對(duì)應(yīng)一個(gè)進(jìn)程,并行是指多個(gè)軟件一起運(yùn)行,實(shí)際上分時(shí)復(fù)用而已,并發(fā)是指某個(gè)軟件在運(yùn)行的時(shí)候把計(jì)算分給多個(gè)CPU同時(shí)進(jìn)行計(jì)算,是真正的同一時(shí)間內(nèi)一起發(fā)生的事情。

PHP-fpm使用的就是多進(jìn)程模型。

HHVM它選擇的是多線程模型。

對(duì)于某個(gè)服務(wù)而言,譬如web服務(wù),主要考慮它的并發(fā)能力,就是單位時(shí)間內(nèi)能處理的請(qǐng)求數(shù)量。而并行計(jì)算就是為了提高并發(fā)能力的。脫離nginx或者apache來說,php的并行處理能力,既可以用多進(jìn)程的模型來提高,也可以用多線程的模型來提高。最簡(jiǎn)單的情況下,php提供單進(jìn)程單線程的方式來提供服務(wù),每次之處理一個(gè)請(qǐng)求,如果請(qǐng)求的處理速度足夠快,一秒時(shí)間內(nèi)并發(fā)能力也可以算是強(qiáng)的,但是這樣比較浪費(fèi)資源,所以往往會(huì)根據(jù)CPU、內(nèi)存、網(wǎng)絡(luò)的情況來設(shè)置多進(jìn)程、多線程或者多服務(wù)器來提高并發(fā)能力。

php采集大數(shù)據(jù)的方案

1、建議你讀寫數(shù)據(jù)和下載圖片分開,各用不同的進(jìn)程完成。

比如說,取數(shù)據(jù)用get-data.php,下載圖片用get-image.php。

2、多進(jìn)程的話,php可以簡(jiǎn)單的用pcntl_fork()。這樣可以并發(fā)多個(gè)子進(jìn)程。

但是我不建議你用fork,我建議你安裝一個(gè)gearman worker。這樣你要并發(fā)幾個(gè),就啟幾個(gè)worker,寫代碼簡(jiǎn)單,根本不用在代碼里考慮thread啊,process等等。

3、綜上,解決方案這樣:

(1)安裝gearman worker。

(2)寫一個(gè)get-data.php,在crontab里設(shè)置它每5分鐘執(zhí)行一次,只負(fù)責(zé)讀數(shù)據(jù),然后把讀回來的數(shù)據(jù)一條一條的扔到 gearman worker的隊(duì)列里;

然后再寫一個(gè)處理數(shù)據(jù)的腳本作為worker,例如叫process-data.php,這個(gè)腳本常駐內(nèi)存。它作為worker從geraman 隊(duì)列里讀出一條一條的數(shù)據(jù),然后跟你的數(shù)據(jù)庫(kù)老數(shù)據(jù)比較,進(jìn)行你的業(yè)務(wù)邏輯。如果你要10個(gè)并發(fā),那就啟動(dòng)10個(gè)process-data.php好了。處理完后,如果圖片地址有變動(dòng)需要下載圖片,就把圖片地址扔到 gearman worker的另一個(gè)隊(duì)列里。

(3)再寫一個(gè)download-data.php,作為下載圖片的worker,同樣,你啟動(dòng)10個(gè)20個(gè)并發(fā)隨便你。這個(gè)進(jìn)程也常駐內(nèi)存運(yùn)行,從gearman worker的圖片數(shù)據(jù)隊(duì)列里取數(shù)據(jù)出來,下載圖片

4、常駐進(jìn)程的話,就是在代碼里寫個(gè)while(true)死循環(huán),讓它一直運(yùn)行好了。如果怕內(nèi)存泄露啥的,你可以每循環(huán)10萬次退出一下。然后在crontab里設(shè)置,每分鐘檢查一下進(jìn)程有沒有啟動(dòng),比如說這樣啟動(dòng)3個(gè)process-data worker進(jìn)程:

* * * * * flock -xn /tmp/process-data.1.lock -c '/usr/bin/php /process-data.php /dev/null 21'

* * * * * flock -xn /tmp/process-data.2.lock -c '/usr/bin/php /process-data.php /dev/null 21'

* * * * * flock -xn /tmp/process-data.3.lock -c '/usr/bin/php /process-data.php /dev/null 21'

不知道你明白了沒有

php多線程

以下都是轉(zhuǎn)載, 簡(jiǎn)單說下, php是不支持多線程的。。。。

PHP語言本身是不支持多線程的. 總結(jié)了一下網(wǎng)上關(guān)于PHP模擬多線程的方法, 總的來說, 都是利用了PHP的好伙伴們本身所具有的多線程能力. PHP的好伙伴指的就是LINUX和APACHE啦, LAMP嘛.

另外, 既然是模擬的, 就不是真正的多線程. 其實(shí)只是多進(jìn)程. 進(jìn)程和線程是兩個(gè)不同的概念. 好了, 以下方法都是從網(wǎng)上找來的.

1. 利用LINUX操作系統(tǒng)

?php

for ($i=0;$i10;$i++) {

echo $i;

sleep(5);

}

?

上面存成test.php, 然后寫一段SHELL代碼

#!/bin/bash

for i in 1 2 3 4 5 6 7 8 9 10

do

php -q test.php

done

2. 利用fork子進(jìn)程(其實(shí)同樣是利用LINUX操作系統(tǒng))

?php

declare(ticks=1);

$bWaitFlag = FALSE; /// 是否等待進(jìn)程結(jié)束

$intNum = 10; /// 進(jìn)程總數(shù)

$pids = array(); /// 進(jìn)程PID數(shù)組

echo ("Startn");

for($i = 0; $i $intNum; $i++) {

$pids[$i] = pcntl_fork();/// 產(chǎn)生子進(jìn)程,而且從當(dāng)前行之下開試運(yùn)行代碼,而且不繼承父進(jìn)程的數(shù)據(jù)信息

if(!$pids[$i]) {

// 子進(jìn)程進(jìn)程代碼段_Start

$str="";

sleep(5+$i);

for ($j=0;$j$i;$j++) {$str.="*";}

echo "$i - " . time() . " $str n";

exit();

// 子進(jìn)程進(jìn)程代碼段_End

}

}

if ($bWaitFlag)

{

for($i = 0; $i $intNum; $i++) {

pcntl_waitpid($pids[$i], $status, WUNTRACED);

echo "wait $i - " . time() . "n";

}

}

echo ("Endn");

?

3. 利用WEB SERVER, PHP不支持多線程, APACHE可是支持的, 呵呵.

假設(shè)我們現(xiàn)在運(yùn)行的是a.php這個(gè)文檔. 但是我在程式中又請(qǐng)求WEB服務(wù)器運(yùn)行另一個(gè)b.php

那么這兩個(gè)文檔將是同時(shí)執(zhí)行的.

?php

function runThread()

{

$fp = fsockopen('localhost', 80, $errno, $errmsg);

fputs($fp, "GET /a.php?act=brnrn");

fclose($fp);

}

function a()

{

$fp = fopen('result_a.log', 'w');

fputs($fp, 'Set in ' . Date('h:i:s', time()) . (double)microtime() . "rn");

fclose($fp);

}

function b()

{

$fp = fopen('result_b.log', 'w');

fputs($fp, 'Set in ' . Date('h:i:s', time()) . (double)microtime() . "rn");

fclose($fp);

}

if(!isset($_GET['act'])) $_GET['act'] = 'a';

if($_GET['act'] == 'a')

{

runThread();

a();

}

else if($_GET['act'] == 'b') b();

?

當(dāng)然啦,也可以把需要多線程處理的部分交給JAVA去處理, 然后在PHP里調(diào)用, 哈哈.

?php

system('java multiThread.java');

?

PHP如何解決網(wǎng)站的大數(shù)據(jù)大流量與高并發(fā)

使用緩存,比如memcache,redis,因?yàn)樗鼈兪窃趦?nèi)存中運(yùn)行,所以處理數(shù)據(jù),返回?cái)?shù)據(jù)非???,所以可以應(yīng)對(duì)高并發(fā)。

2.增加帶寬和機(jī)器性能,1M的帶寬同時(shí)處理的流量肯定有限,所以在資源允許的情況下,大帶寬,多核cpu,高內(nèi)存是一個(gè)解決方案。

3.分布式,讓多個(gè)訪問分到不同的機(jī)器上去處理,每個(gè)機(jī)器處理的請(qǐng)求就相對(duì)減少了。

簡(jiǎn)單說些常用技術(shù),負(fù)載均衡,限流,加速器等


網(wǎng)站名稱:php利用線程操作大數(shù)據(jù),php多線程
路徑分享:http://weahome.cn/article/hcccpg.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部