使用php+swoole對client數據實時更新(一)

jopen 8年前發布 | 20K 次閱讀 Swoole HTML5 PHP開發

如果想對一個列表做實時的更新,傳統的做法是采用輪詢的方式。以web為例,通過Ajax定時請求服務端然后獲取數據顯示在頁面。這種方式實現簡單,缺點就是浪費資源。HTTP1.1新增加了對websocket的支持,這樣就可以將被動展示轉變為主動通知。也就是通過websocket與服務端保持持久鏈接,一旦數據發生變化,由server通知client數據有更新,然后再進行刷新等操作。這樣就省去了很多不必要的被動請求,節省了服務器資源。

要實現一個webscoket的程序,首先需要使用支持html5的瀏覽器

if(ws === null){
    var wsServer = 'ws://'+ location.hostname +':8888';
    ws = new WebSocket(wsServer);
    ws.onopen = function(){
        console.log("socket連接已打開");
    };
    ws.onmessage = function(e){
        console.log("message:" + e.data);
    };
    ws.onclose = function(){
        console.log("socket連接已斷開");
    };
    ws.onerror = function(e){
        console.log("ERROR:" + e.data);
    };

    //離開頁面時關閉連接
    $(window).bind('beforeunload',function(){
            ws.close();
        }
    );
}

這樣就實現了一個client,不過事情還遠沒有結束。上面的代碼只是簡單的進行了連接,對話,關閉等基本動作。如果想和服務端進行通訊,必須要有更具體的方案。比如收到message時判斷類型進行進一步操作。

服務端:此處采用Swoole進行php服務端的websocket開發,使用swoole進行php的websocket開發非常簡單,而且它還支持httpserver的支持。詳細的介紹可以參考這里 http://wiki.swoole.com/

    $server = new swoole_websocket_server("0.0.0.0", 8888);

    $server->on('open', function (swoole_websocket_server $server, $request) {
        echo "server: handshake success with fd{$request->fd}\n";
    });

    $server->on('message', function (swoole_websocket_server $server, $frame) {
        echo "receive from {$frame->fd}:{$frame->data},opcode:{$frame->opcode},fin:{$frame->finish}\n";
        $server->push($frame->fd, "this is server");
    });

    $server->on('close', function ($ser, $fd) {
        echo "client {$fd} closed\n";
    });

    $server->start();

ps.swoole是一個php的擴展,安裝方式可以參考這里 http://git.oschina.net/matyhtf/swoole

先寫到這里,下一篇會寫一些更具體的操作

來自: http://www.cnblogs.com/JasonLeemz/p/5109226.html

 本文由用戶 jopen 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
 轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
 本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!