Workerman+Thinkphp5搭建高效能的PHP socket 伺服器框架
Workerman是一款純PHP開發的開源高效能的PHP socket 伺服器框架。被廣泛的用於手機app、手遊服務端、網路遊戲伺服器、聊天室伺服器、硬體通訊伺服器、智慧家居、車聯網、物聯網等領域的開發。 支援TCP長連線,支援Websocket、HTTP等協議,支援自定義協議。基於workerman開發者可以更專注於業務邏輯開發,不必再為PHP Socket底層開發而煩惱。這些都是thinkphp5開發文件裡面的資料,但是文件裡面有些事沒有寫清楚的,下面小編自身從頭到尾寫一個完整的案例。
首先通過 composer 安裝,切換到專案根目錄,輸入命令
composer require topthink/think-worker
如果需要在window下做服務端,還需要
composer require workerman/workerman-for-win
首先要明白composer之後workerman是安裝到哪去了,安裝到tp5專案下vendor目錄中
執行出現錯誤PHP Fatal error: Call to undefined function Workerman\Lib\pcntl_signal(),需要刪除vendor\workerman\workerman,防止命名覆蓋
服務端使用示例如下:
新增啟動服務檔案server.php,在專案根目錄
<?php #!/usr/bin/env php define('APP_PATH', __DIR__ . '/application/'); define('BIND_MODULE','push/Worker'); // 載入框架引導檔案 require __DIR__ . '/thinkphp/start.php';
新增服務處理類,在tp5目錄中application\push\controller\Worker.php中新建worker.php控制器,其中x.x.x.x:2346為伺服器的私有ip地址和埠,檢視伺服器私有ip地址可以通過ifconfig來檢視inet addr就是私有ip地址。
埠這塊很多人都會出錯,因為伺服器再預設情況下是不會開啟你要配置的2346埠的,所有為保證配置成功,你首先需要去伺服器防火牆新增一個允許訪問2346的埠的規則。下面是詳細控制器程式碼
<?php namespace app\push\controller; use think\worker\Server; class Worker extends Server{ protected $socket = 'websocket://x.x.x.x:2346'; /** * 收到資訊 * @param $connection * @param $data */ public function onMessage($connection, $data) { $connection->send('我收到你的資訊了'); $connection->send('你給我傳送了'.$data); } /** * 當連線建立時觸發的回撥函式 * @param $connection */ public function onConnect($connection) { } /** * 當連線斷開時觸發的回撥函式 * @param $connection */ public function onClose($connection) { } /** * 當客戶端的連線上發生錯誤時觸發 * @param $connection * @param $code * @param $msg */ public function onError($connection, $code, $msg) { echo "error $code $msg\n"; } /** * 每個程序啟動 * @param $worker */ public function onWorkerStart($worker) { } }
在命令列下執行,啟動監聽服務
php server.php start
開啟了服務後,如果成功的話我們可以看到,start success!
最後客戶端程式碼需要注意的是y.y.y.y為你伺服器的公網ip地址,這個地址就是通常域名需要解析的ip地址。搞清楚了這點以後我們再開啟chrome瀏覽器,再開啟專案的任一網頁(js跨域不能通訊),按F12開啟除錯控制檯,在Console一欄輸入(我建議大家把下面程式碼放入到html頁面用js執行)
ws = new WebSocket("ws://y.y.y.y:2346"); ws.onopen = function() { alert("連線成功"); ws.send('tom'); alert("給服務端傳送一個字串:tom"); }; ws.onmessage = function(e) { alert("收到服務端的訊息:" + e.data); };
最後都配置成功的話,我們切換到那個有js程式碼的頁面可以看到
如果大家還有配置workerman其他方面的錯誤可以查閱:http://www.100txy.com/article/138.html