- N +

php socket編程?簡單理解php的socket編程

php多線程教程

PHP+shell實現多線程的方法

先寫個簡單的php代碼,這里為了讓腳本執行時間更長,方便看效果,sleep一下,呵呵!先看下test.php的代碼:ls

PHP代碼:

for($i=0;$i<10;$i++){

echo$i;

sleep(10);

}

?>

在看下shell腳本的代碼,非常簡單

#!/bin/bash

foriin12345678910

do

/usr/bin/php-q/var/www/html/test.php&

done

注意到在請求php代碼的那行有一個&符號嗎,這個是關鍵,不加的話是不能進行多線程的,&表示講服務推送到后臺執行,因此,在shell的每次的循環中不必等php的代碼全部執行完在請求下一個文件,而是同時進行的,這樣就實現了多線程,下面運行下shell看下效果,這里你將看到10個test.php進程再跑,再利用linux的定時器,定時請求這個shell,在處理一些需要多線程的任務,例如,批量下載時,非常好用!

php中用WEB服務器實現多線程

假設我們現在運行的是a.php這個文件.但是我在程序中又請求WEB服務器運行另一個b.php,那么這兩個文件將是同時執行的.(PS:一個鏈接請求發送之后,WEB服務器就會執行它,而不管客戶端是否已經退出)

有些時候,我們想運行的不是另一個文件,而是本文件中的一部分代碼.該怎么辦呢?

其實可是通過參數來控制a.php來運行哪一段程序.

下面看一個例子:

//a.php,b.php

PHP代碼:--------------------------------------------------------------------------------

functionrunThread()

{

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

fputs($fp,"GET/b.php?act=b\r\n\r\n");//這里的第二個參數是HTTP協議中規定的請求頭

//不明白的請看RFC中的定義

fclose($fp);

}

functiona()

{

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

fputs($fp,'Setin'.Date('h:i:s',time()).(double)microtime()."\r\n");

fclose($fp);

}

functionb()

{

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

fputs($fp,'Setin'.Date('h:i:s',time()).(double)microtime()."\r\n");

fclose($fp);

}

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

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

{

runThread();

a();

}

elseif($_GET['act']=='b')b();

?>

--------------------------------------------------------------------------------

打開result_a.log和result_b.log比較一下兩個文件的中訪問的時間.大家會發現,這兩個的確是在不同線程中運行的.有些時間完全一樣.

上面只是一個簡單的例子,大家可以改進成其它形式.

既然PHP中也能多線程了,那么問題也來了,那就是同步的問題.我們知道PHP本身是不支持多線程的.所以更不會有什么像Java中synchronize的方法了.那我們該如何做呢.

1.盡量不訪問同一個資源.以避免沖突.但是可以同時像數據庫操作.因為數據庫是支持并發操作的.所以在多線程的PHP中不要向同一個文件中寫入數據.如果必須要寫的話,用別的方法進行同步..如調用flock對文件進行加鎖等.或建立臨時文件并在另外的線程中等待這個文件的消失while(file_exits('xxx'));這樣就等于這個臨時文件存在時,表示其實線程正在操作

如果沒有了這個文件,說明其它線程已經釋放了這個.

2.盡量不要從runThread在執行fputs后取這個socket中讀取數據.因為要實現多線程,需要的用非阻塞模式.即在像fgets這樣的函數時立即返回..所以讀寫數據就會出問題.如果使用阻塞模式的話,程序就不算是多線程了.他要等上面的返回才執行下面的程序.所以如果需要交換數據最后利用外面文件或數據中完成.實在想要的話就用socket_set_nonblock($fp)來實現.

說了這么多,倒底這個有沒有實際的意義呢?在什么時候需要這種用這種方法呢?

答案是肯定的.大家知道.在一個不斷讀取網絡資源的應用中,網絡的速度是瓶頸.如果采多這種形式就可以同時以多個線程對不同的頁面進行讀取.

本人做的一個能從8848、soaso這些商城網站搜索信息的程序。還有一個從阿里巴巴網站上讀取商業信息和公司目錄的程序也用到了此技術。因為這兩個程序都是要不斷的鏈接它們的服務器讀取信息并保存到數據庫。利用此技術正好消除了在等待響應時的瓶頸。

php模擬實現多線程的三種方法

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

另外,既然是模擬的,就不是真正的多線程.其實只是多進程.進程和線程是兩個不同的概念.好了,以下方法都是從網上找來的.

1.利用LINUX操作系統

for($i=0;$i<10;$i++){

echo$i;

sleep(5);

}

?>

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

#!/bin/bash

foriin12345678910

do

php-qtest.php&

done

2.利用fork子進程(其實同樣是利用LINUX操作系統)

declare(ticks=1);

$bWaitFlag=FALSE;///是否等待進程結束

$intNum=10;///進程總數

$pids=array();///進程PID數組

echo("Startn");

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

$pids[$i]=pcntl_fork();///產生子進程,而且從當前行之下開試運行代碼,而且不繼承父進程的數據信息

if(!$pids[$i]){

//子進程進程代碼段_Start

$str="";

sleep(5+$i);

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

echo"$i->".time()."$strn";

exit();

//子進程進程代碼段_End

}

}

if($bWaitFlag)

{

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

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

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

}

}

echo("Endn");

?>

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

假設我們現在運行的是a.php這個文檔.但是我在程式中又請求WEB服務器運行另一個b.php

那么這兩個文檔將是同時執行的.(代碼同上)

當然啦,也可以把需要多線程處理的部分交給JAVA去處理,然后在PHP里調用,哈哈.

system('javamultiThread.java');

?>

擴展資料:PHP即“超文本預處理器”,是一種通用開源腳本語言。PHP是在服務器端執行的腳本語言,與C語言類似,是常用的網站編程語言。PHP獨特的語法混合了C、Java、Perl以及PHP自創的語法。利于學習,使用廣泛,主要適用于Web開發領域。

如何利用本地的PHP服務端,利用socket編程,實現對不同客戶端的數據通信

你可以先自學一下php的socket編程框架,workerman,或者swoole。但是基于http協議也可以對不同客戶端進行通信的,如果不涉及硬件,及嵌入式系統的話,http就夠了。

php動態多文件上傳

我用過更毒的辦法,用socket,完全不是受PHP.INI限制,可實時顯示上傳進度,不過需要你的服務器的防火墻設置有一定要求,因為用這個辦法,要動態打開服務器高于1024以上的端口用于接收數據

一次完整的http請求過程是怎樣的

謝邀~

我們打開瀏覽器,在地址欄輸入\www.wukong.com\,幾秒后瀏覽器打開悟空問答的頁面,那么這幾秒鐘內發生了哪些事情,我就帶大家一起看看完整的流程:

解析URL

瀏覽器首先會對輸入的URL進行驗證,如果不合法的時候,那么會把輸入的文字傳給默認的搜索引擎,比如你只在地址欄輸入“悟空問答”幾個字。

如果URL通過驗證,那么可以解析得到協議(http或者https)、域名(wukong)、資源(首頁)等信息。

DNS查詢

瀏覽器會先檢查域名信息是否在緩存中。

再檢查域名是否在本地的Hosts文件中。

如果還不在,那么瀏覽器會向DNS服務器發送一個查詢請求,獲得目標服務器的IP地址。

TCP封包及傳輸

這時候瀏覽器獲得了目標服務器的IP(DNS返回)、端口(URL中包含,沒有就使用默認),瀏覽器會調用庫函數socket,生成一個TCP流套接字,也就是完成了TCP的封包。

TCP封包完成之后,就可以傳輸了,在完成“你瞅啥”,“瞅你咋地”,“來,過來嘮嘮”一系列操作之后,瀏覽器和服務器就完成了TCP的三次握手,建立了連接,后面就可以請求服務器資源了。

服務器接收請求并相應

HTTP有很多請求方法,比如:GET/POST/PUT/DELETE等等,我們瀏覽器輸入URL這種,是GET方法。

服務器接收到GET請求,服務器根據請求信息,獲得相應的相應內容。例如我們輸入的是:\www.wukong.com\,那么意味著訪問首頁文件。

瀏覽器解析并渲染

瀏覽器從服務器拿到了想要訪問的資源,大多數時候,這個資源就是HTML頁面,當然也可能是一個其他類型的文件。

瀏覽器先對HTML文檔進行解析,生成解析樹(以DOM元素為節點的樹)。

加載頁面的外部資源,比如JS、CSS、圖片。

遍歷DOM樹,并計算每個節點的樣式,最終完成渲染,變成我們看到的頁面。

這次請求響應之后,會斷開連接,就這樣,完成了一次HTTP的請求。

我將持續分享Java開發、架構設計、程序員職業發展等方面的見解,希望能得到你的關注。

php socket如何實現語音聊天

實現PHP語音聊天的方法有很多種,這里只介紹其中一種基于WebSocket的實現方法。

1.服務端:

(1)使用Apache服務器,并啟用WebSocket模塊

(2)使用PHP語言構建WebSocket服務端程序,在程序中用socket_bind()函數指定端口號并等待客戶端連接

(3)使用fread()函數讀取客戶端傳遞的語音數據,并通過socket_send()函數將數據傳遞給與之通信的客戶端

(4)客戶端退出或斷開連接時,使用socket_close()函數關閉連接

2.客戶端:

(1)使用HTML和JavaScript構建客戶端頁面

(2)使用MediaRecorder對象錄制用戶的語音并將其轉化為Blob數據

(3)使用WebSocketAPI發送Blob數據至服務端,同時監聽服務端的響應并播放語音數據

(4)結束語音聊天的操作同樣使用WebSocketAPI,使用WebSocketAPI發送相應的語音結束標志至服務端即可

返回列表
上一篇:
下一篇: