• 使用php+swoole对client数据实时更新(上)


    如果想对一个列表做实时的更新,传统的做法是采用轮询的方式。以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}
    ";
        });
    
        $server->on('message', function (swoole_websocket_server $server, $frame) {
            echo "receive from {$frame->fd}:{$frame->data},opcode:{$frame->opcode},fin:{$frame->finish}
    ";
            $server->push($frame->fd, "this is server");
        });
    
        $server->on('close', function ($ser, $fd) {
            echo "client {$fd} closed
    ";
        });
    
        $server->start();
    
    

    ps.swoole是一个php的扩展,安装方式可以参考这里http://git.oschina.net/matyhtf/swoole

    先写到这里,下一篇会写一些更具体的操作

  • 相关阅读:
    通过crontab命令创建任务
    linux 通过at命令创建任务
    在linux中如何实现定时发送邮件到指定邮箱,监测任务
    python发送邮件
    序列化分析
    文件写入
    导入excel成一个list集合不支持大文件倒入(优化点在于分批分线程导入)
    react重学
    关于java集合排序
    fiddler还是浏览器的问题
  • 原文地址:https://www.cnblogs.com/JasonLeemz/p/5109226.html
Copyright © 2020-2023  润新知