PHP程序阻塞和非阻塞的區(qū)別是:阻塞調(diào)用結(jié)果返回之前,當(dāng)前線程會(huì)被掛起,調(diào)用者不會(huì)接著往下執(zhí)行;而非阻塞調(diào)用結(jié)果返回之前,該調(diào)用不會(huì)阻塞當(dāng)前線程,可以繼續(xù)向下執(zhí)行。
本文操作環(huán)境:Windows10系統(tǒng)、PHP7.1版、Dell G3電腦。
php程序阻塞與非阻塞的區(qū)別是什么
阻塞和非阻塞關(guān)注的是程序在等待調(diào)用結(jié)果(消息,返回值)時(shí)的狀態(tài).
阻塞調(diào)用是指調(diào)用結(jié)果返回之前,當(dāng)前線程會(huì)被掛起。調(diào)用線程只有在得到結(jié)果之后才會(huì)返回。
非阻塞調(diào)用指在不能立刻得到結(jié)果之前,該調(diào)用不會(huì)阻塞當(dāng)前線程。
1.php并發(fā)阻塞
對(duì)于php來(lái)說(shuō)并發(fā)是個(gè)問(wèn)題,工作中經(jīng)常會(huì)碰到一些,寫(xiě)庫(kù)之前的查詢,判斷數(shù)據(jù)是否存在,但是如果并發(fā)的情況下,就會(huì)導(dǎo)致數(shù)據(jù)重復(fù)寫(xiě)入,而你的判斷也成了虛設(shè)。所以有了阻塞,我們需要把請(qǐng)求一條一條的執(zhí)行。
簡(jiǎn)單介紹:
1.首先,讀寫(xiě)方式打開(kāi)或者創(chuàng)建文件lock.txt文件
2.給lock.txt文件上 "獨(dú)占鎖",上鎖成功后就可以進(jìn)行下一步"處理訂單商品數(shù)據(jù)了"
3.處理完數(shù)據(jù)后,要"釋放鎖”,以及fclose關(guān)閉打開(kāi)的文件
注意:給文件“獨(dú)占鎖”后,如果再?zèng)]有里面的“釋放鎖”,會(huì)出現(xiàn)非??ǖ那闆r
public function index(){ $fp = fopen("lock.txt", "w+"); if(flock($fp,LOCK_EX)) { $find=Db::name('user')->where('username','name2')->find(); if($find){ $data['username']='name3'; $data['password']=''; $data['password_m']=''; Db::name('user')->insert($data); }else{ $data['username']='name2'; $data['password']=''; $data['password_m']=''; Db::name('user')->insert($data); } flock($fp,LOCK_UN); } fclose($fp); return 'success'; }
注意:對(duì)于小并發(fā)可行,而且性能不會(huì)出現(xiàn)大的影響。并發(fā)小于500較好,如果過(guò)高的話,建議使用隊(duì)列模式。
2.php非阻塞模式
非阻塞模式我們常用在php程序內(nèi)部調(diào)用第三方api接口,或者不需要等待結(jié)果的程序。
舉一個(gè)簡(jiǎn)單的例子。發(fā)送郵件,你要發(fā)送給你的所有的老大,那么你需要全部都發(fā)送一遍,也許你得寫(xiě)一個(gè)循環(huán),那么這一個(gè)循環(huán)中發(fā)郵件的方法需要執(zhí)行時(shí)間,需要拿到返回值,執(zhí)行下一次循環(huán),這個(gè)時(shí)間依次累加,最后時(shí)間會(huì)邊的很長(zhǎng),
那么這種被稱之為阻塞,而我們一直想要的是提交過(guò)去,不需要等待返回?cái)?shù)據(jù),你就循環(huán)的跑一遍就好了,那么我們想的這個(gè)就是非阻塞模式。對(duì)于這種的話,php也沒(méi)有什么好的函數(shù)來(lái)處理,所以我們做的最多的還是隊(duì)列出來(lái),發(fā)郵件的時(shí)候,
根據(jù)隊(duì)列去執(zhí)行,其實(shí)用到的還是阻塞模式。但是我們的請(qǐng)求執(zhí)行時(shí)間會(huì)被壓縮的很短,最常用的就是調(diào)用API接口,而你此時(shí)又不關(guān)心返回值的時(shí)候。
推薦學(xué)習(xí):《PHP視頻教程》