方法一:PECL安裝
安裝依賴包php
apt-get install libpcre3 libpcre3-devhtml
安裝swoolegit
pecl install swoolegithub
修改PHP配置 php.ini 加載 swooleweb
驗證安裝與加載:apache
php -m | grep swoole小程序
方法二:源碼編譯安裝
1.下載swoole
下載源碼包,解壓,並切換到解壓目錄vim
wget -c https://github.com/swoole/swoole-src/archive/v2.0.6.tar.gz微信小程序
解壓:tar -zxvf v2.0.6.tar.gz數組
cd swoole-src-2.0.6/
2.編譯安裝
使用phpize來生成php編譯配置
.configure來作編譯配置檢測
make進行編譯 make install 進行安裝
執行命令:
phpize
./configure
make
make install
正常狀況下會出現
Installing shared extensions : /usr/lib64/php/modules
表示 在上述目錄 /usr/lib64/php/modules 中生成了 swoole.so 文件
3.修改配置文件,加載模塊
要在PHP配置文件 php.ini 添加swoole模塊. 注意,PHP7模塊配置文件是單獨分開的,只需在 /etc/php.d/ 目錄中添加模塊配置文件 swoole.ini 便可
進入到 /etc/php.d/ 執行命令
vim swoole.ini
在swoole.ini 中輸入
;Enable swoole extension module
extension=swoole.so
保存.
4.重啓服務,模塊是否已加載
service apache2 restart
php -m | grep swoole
三 .簡單示例
1.TCP服務器
建立swoole_test.php 文件,內容以下: 示例代碼
切換到所建立swoole_test.php 所在目錄,執行命令
php swoole_test.php (本人電腦多版本PHP 故指明版本 php7.0)
監聽9898 端口的程序已啓動執行
新打開一個終端窗口,使用telnet 鏈接服務端監聽的端口,輸入文字,觀察.能夠發現 鏈接時 監聽鏈接的回調函數正常輸出了 如圖:
示例只是簡單的模擬個回覆 ,客戶端發什麼,服務端就回什麼
退出Telnet 鏈接 觀察 服務器顯示什麼
Ctrl + ]
quit
服務器 顯示 Client:Close
上述telnet 鏈接測試 可用swoole_client 同理測試
注:swoole_client 是針對TCP服務器的客戶端,即:swoole_server
建立swoole_client.php,內容以下:
1 function client($argv) 2 { 3 $client= new swoole_client(SWOOLE_SOCK_TCP); 4 //鏈接到服務器 5 if (!$client->connect($argv[1],$argv[2],'0.5')) { 6 die("connect failed."); 7 } 8 9 //向服務器發送數據 10 if (!$client->send('data: '.$argv[3])) { 11 die("send failed."); 12 } 13 echo "success send data: ".$argv[3]."\n"; 14 $client->close(); 15 } 16 client($argv);
打開終端執行:
php7.0 swoole_client.php 127.0.0.1 9898 hello
數據 'hello' 發送成功.
PHP 中可用 exec()函數執行:exec('php7.0 swoole_client.php 127.0.0.1 9898 hello'),可打印日誌,跟蹤過程.
2. webSocket服務器程序.
內置的webSocket服務器支持,經過幾行PHP代碼就能夠寫出一個異步非阻塞多進程的webSocket服務 以下例:
①.html:
1 <table> 2 <tr> 3 <td><input type="text" id="text"></td> 4 </tr> 5 <tr> 6 <td><input type="button" value="點擊" onclick="ab()"></td> 7 </tr> 8 </table> 9 <div id="div" style="width:200px; height:200px;" }> 10 11 </div>
②.客戶端js:
目前瀏覽器安基本都內置了js語言的webSocket客戶端,微信小程序開發框架也內置了webSocket客戶端,除此以外異步的php程序中能夠使用swoole\http\client做爲websocket客戶端,注意的是:非webSocket客戶端不能與webSocket服務器通信.
1 //引入jQuery 2 <script> 3 var wsServer = 'ws://127.0.0.1:9999';//這裏的IP應該更改 4 var websocket = new WebSocket(wsServer); 5 websocket.onopen = function (evt) { 6 console.log("Connected to WebSocket server."); 7 }; 8 9 websocket.onclose = function (evt) { 10 console.log("Disconnected"); 11 }; 12 13 websocket.onmessage = function (evt) { 14 $('#div').append(evt.data+"<br>"); 15 // document.getElementById('div').style.background = evt.data; 16 console.log('Retrieved data from server: ' + evt.data); 17 }; 18 19 websocket.onerror = function (evt, e) { 20 console.log('Error occured: ' + evt.data); 21 }; 22 function ab(){ 23 var zhi=document.getElementById('text').value; 24 websocket.send(zhi); 25 } 26 </script>
webSocket服務器: webSocket_server.php
1 //建立websocket服務器對象,監聽0.0.0.0:9502端口 2 $ws = new swoole_websocket_server("0.0.0.0", 9999); 3 4 //監聽WebSocket鏈接打開事件 5 $ws->on('open', function ($ws, $request) { 6 var_dump($request->fd, $request->get, $request->server); 7 //獲取全部鏈接人存爲數組 8 9 $GLOBALS['fd'][] = $request->fd; 10 //$ws->push($request->fd, "hello, welcome\n"); 11 }); 12 13 //監聽WebSocket消息事件 14 $ws->on('message', function ($ws, $frame) { 15 echo "Message: {$frame->data}\n"; 16 17 //循環全部鏈接人發送內容 18 19 foreach($GLOBALS['fd'] as $key => $val){ 20 $ws->push($val,$frame->data); 21 } 22 //$ws->push($frame->fd, "{$frame->data}"); 23 }); 24 25 //監聽WebSocket鏈接關閉事件 26 $ws->on('close', function ($ws, $fd) { 27 echo "client-{$fd} is closed\n"; 28 }); 29 30 $ws->start();
運行 終端運行 php webSocket_server.php
這裏只作了簡單的示例測試,具體應用參考官方文檔 :https://wiki.swoole.com/