其實就PHP而言,可以用2種方式來做:
創(chuàng)新互聯(lián)建站是一家專業(yè)提供烏蘭企業(yè)網(wǎng)站建設(shè),專注與網(wǎng)站設(shè)計、成都網(wǎng)站制作、H5頁面制作、小程序制作等業(yè)務(wù)。10年已為烏蘭眾多企業(yè)、政府機構(gòu)等服務(wù)。創(chuàng)新互聯(lián)專業(yè)網(wǎng)絡(luò)公司優(yōu)惠進行中。
(1)在PHP里使用shell_exec的函數(shù),以shell的方式,啟動一個獨立的PHP腳本執(zhí)行。這種方式,其實相當(dāng)于在Web服務(wù)器處理過程中,獨立起了一個shell進程處理你的任務(wù)。這里,需要特別注意的是shell_exec的服務(wù)器安全,注意校驗參數(shù),小心避免被帶入shell命令中。這個是比較容易實現(xiàn)的方式。
(2)使用PHP實現(xiàn)一個Server,監(jiān)聽一個端口,為Web端提供服務(wù)。這里的實現(xiàn)方式有很多,通常要配合擴展,例如原生的pthread(多線程),開源擴展swoole等等。
建議先使用外部工具連接數(shù)據(jù)庫試試,看是否是數(shù)據(jù)庫支撐不了大規(guī)模數(shù)據(jù)的寫入查詢等等。檢查數(shù)據(jù)庫的連接數(shù),php配置的連接數(shù)
如果是連接數(shù)滿了,簡單粗暴的方式,修改連接數(shù)配置。如果是mysql所消耗的內(nèi)存服務(wù)問題,就要修改mysql內(nèi)存,加大配置。優(yōu)化一下耗時長的業(yè)務(wù),這個和程序端的代碼,是否為多線程沒有太大的關(guān)系,從你發(fā)出來的情況,就是1個請求耗時太長,讓后其他請求沒有返回,要么是web服務(wù)內(nèi)存吃緊,要么是mysql服務(wù)壓力過大,連接數(shù)用滿的情況,應(yīng)該不太可能。
利用WEB服務(wù)器本身的多線程來處理,從WEB服務(wù)器多次調(diào)用我們需要實現(xiàn)多線程的程序。
PHP中也能多線程了,那么問題也來了,那就是同步的問題。
安徽電腦培訓(xùn)知道PHP本身是不支持多線程的,所以更不會有什么像Java中synchronize的方法了。
那我們該如何做呢?1.盡量不訪問同一個資源。
以避免沖突。
但是可以同時像數(shù)據(jù)庫操作。
因為數(shù)據(jù)庫是支持并發(fā)操作的。
所以在多線程的PHP中不要向同一個文件中寫入數(shù)據(jù)。
如果必須要寫的話,用別的方法進行同步。
如調(diào)用flock對文件進行加鎖等。
或建立臨時文件,并在另外的線程中等待這個文件的消失while(file_exits('xxx'));這樣就等于這個臨時文件存在時,表示其實線程正在操作。
如果沒有了這個文件,說明其它線程已經(jīng)釋放了這個。
2.盡量不要從runThread在執(zhí)行fputs后取這個socket中讀取數(shù)據(jù)。
因為要實現(xiàn)多線程,需要的用非阻塞模式。
即在像fgets這樣的函數(shù)時立即返回。
。
所以讀寫數(shù)據(jù)就會出問題。
如果使用阻塞模式的話,程序就不算是多線程了。
他要等上面的返回才執(zhí)行下面的程序。
所以如果需要交換數(shù)據(jù)最后利用外面文件或數(shù)據(jù)中完成。
實在想要的話就用socket_set_nonblock($fp)來實現(xiàn)。
說了這么多,倒底這個有沒有實際的意義呢?在什么時候需要這種用這種方法呢?答案是肯定的。
大家知道。
在一個不斷讀取網(wǎng)絡(luò)資源的應(yīng)用中,網(wǎng)絡(luò)的速度是瓶頸。
如果采多這種形式就可以同時以多個線程對不同的頁面進行讀取。