PHPSocket.IO是基于workerman開發的php版本的socket.IO服務??捎糜诜掌飨⒌耐扑汀⒘奶焓?、客服系統的開發
使用環境: thinkphp5.0
項目需求
前端下單,后臺接受,并立即做出提示。例如:美團外賣,客戶端下單成功后,商家端就會立即有接單語音提示。
開發環境
(由于需要啟動socket服務,所以需在能夠滿足shell的環境下使用)
socketio 優勢
這里只是我的觀點,畢竟沒有怎么深入研究socketio,所以只是淺顯的一點總結:
初略的看了一下,內存占用很小,而且只有1個進程,根據官方報道來說1個進程也能容納1W人次的高并發,所以,對于我的項目來說,已經綽綽有余
官方文檔
https://github.com/walkor/phpsocket.io
開始開發
安裝 phpsocketio
首先cd到thinkphp的項目根目錄。使用以下命令
composer require workerman/phpsocket.io
( 這里composer不做解釋,如果有什么問題,度娘一下,應該能夠解決 )
安裝好以后,vendor文件夾下面應該就有一個workerman的文件夾,如果存在,就恭喜你,已經安裝完畢了
服務入口文件
回到項目根目錄,新建server.php,開始編輯
#!/usr/bin/env php<?phpdefine('APP_PATH', __DIR__ . '/application/');define('BIND_MODULE','socketio/Server/index');// 加載框架引導文件require __DIR__ . '/thinkphp/start.php';
這里只要寫好就OK。后續的所有東西,可以忽略他的存在
創建服務控制器
上一步的server.php文件里面,模塊綁定到了'socketio/Server/index',這里就需要我們手動創建了。為了能理解,我用目錄展示
├─application 應用目錄│ ├─socketio 新創建目錄│ │ ├─controller │ │ │ ├─Server.php 啟動文件
Server.php
入口文件只是綁定到了這個控制器,所以這個是整個socketio的核心。
<?php/* * (c) U.E Dream Development Studio * * Author: 李益達 - Ekey.Lee <ekey.lee@gmail.com> * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */namespace app/socketio/controller;require_once VENDOR_PATH . "workerman/phpsocket.io/src/autoload.php";use PHPSocketIO/SocketIO;use Workerman/Worker;class Server{ public function index() { $io = new SocketIO(8080);//socket的端口 $io->on('workerStart', function () use ($io) { $inner_http_worker = new Worker('http://0.0.0.0:5880');//這里IP不用改變,用的內網通訊,端口不能與socket端口想通 $inner_http_worker->onMessage = function ($http_connection, $data) use ($io) { $io->emit('new_msg', '44444');//這里寫了固定數據,請根據自己項目需求去做調整,不懂這里的可以看看官方文檔,很清楚 $http_connection->send('ok'); }; $inner_http_worker->listen(); }); // 當有客戶端連接時 $io->on('connection', function ($socket) use ($io) { // 定義chat message事件回調函數 $socket->on('chat message', function ($msg) use ($io) { // 觸發所有客戶端定義的chat message from server事件 $io->emit('chat message from server', $msg); }); }); Worker::runAll(); }}
創建API 觸發socketio
同樣你可以在socketio下面新建一個API控制器,這里僅供測試
public function api() { // 推送的url地址,使用自己的服務器地址 $push_api_url = "http://0.0.0.0:5880";//這里同樣不需要更改IP。只是端口一定需要和server.php onworker的一樣 $post_data = array( "type" => "publish", "content" => "這個是推送的測試數據", ); $ch = curl_init (); curl_setopt ( $ch, CURLOPT_URL, $push_api_url ); curl_setopt ( $ch, CURLOPT_POST, 1 ); curl_setopt ( $ch, CURLOPT_HEADER, 0 ); curl_setopt ( $ch, CURLOPT_RETURNTRANSFER, 1 ); curl_setopt ( $ch, CURLOPT_POSTFIELDS, $post_data ); curl_setopt ($ch, CURLOPT_HTTPHEADER, array("Expect:")); $return = curl_exec ( $ch ); curl_close ( $ch ); var_export($return); }
現在有了server服務端,API觸發端,接下來就需要顯示出來了,就是我們的前端
前端
現在要寫的就是,商家端收到的提示。之前寫的server服務端提供phpsocketio監控與socket服務,API提供事件觸發,也就是有人下單后的觸發,下單作為事件去觸發服務器socket,讓他回應到前端
代碼開始前請注意:這里的端口和域名比較的繞
<script src='//cdn.bootcss.com/socket.io/1.3.7/socket.io.js'></script> <script> // 連接服務端 var socket = io('http://xxxx.com:8080');//這里請填寫你的域名,外網,端口為socket端口 // 后端推送來消息時 socket.on('new_msg', function (msg) {//這里的new_msg請一定要注意,官方文檔都寫的是content,但是后端發送的自定義是new_msg,后端定義成new_msg,前端卻接受content的字段。所以是接受不了的 swal({ title: "包廂點餐提醒", text: "哆啦a夢包廂有新訂單" }) //console.log("收到消息:" + msg); });</script>
以上有兩個我之前出問題的地方
部署完畢開始運行
現在所有的文件就算是部署好了,進入服務器管理,打開shell。cd到項目根目錄。然后執行php server.php start
php server.php start 啟動
php server.php stop 停止
php server.php restart 重啟
php server.php status 當前服務狀態
總結
這次只作為工作總結,因為時間緊迫我也沒有好好去研究socketio的更多東西,可能有些地方有紕漏,但是我100%保證這是本人親自測試,所提到的坑點,都是我一步一步踩過去的。如果有說錯的歡迎指教 ^_^
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VeVb武林網。
新聞熱點
疑難解答
圖片精選