PHP libevent 使用总结
2016-05-19 14:28
651 查看
在根据网上很多资料介绍 libevent 如何使用或者代码分析;不过,大多数都是C 方面一些底层介绍。
在 php 层面上介绍相关应用相对很少,不知道是否在 php 使用 libevent 组件的本身就比较少. 而且网主记载使用例子非常简单. 好啦, 我就长话短说,下面就直接上代码了。
注意: 在设置事件监听上,第四个参数. 我使用 一个Array 来做. 在网上很多例子都是使用 function 名称. 但这样做不利于业务逻辑编写,所以,这里作出了一些修改.
注: 这个部分主要都是设定服务端接收一个Socket 连接的情况下, 服务端需要处理一些必要事情.如: 监听信息流事件,监听类型以及有信息流触发的处理方法. 这些事情都是对应每个Socket 来做相关处理.
展示的代码相对比较简单,但跌跌碰碰用了不少时间进行摸索.总的来讲,这样构建PHP 服务端会比用纯Socket组件要稳定.
在 php 层面上介绍相关应用相对很少,不知道是否在 php 使用 libevent 组件的本身就比较少. 而且网主记载使用例子非常简单. 好啦, 我就长话短说,下面就直接上代码了。
下面为定义 libevent 监听端口以及监听IP
[code=language-php] public function Start(){ $this->server_sock = stream_socket_server ('tcp://0.0.0.0:'.$port, $errno, $errstr); @stream_set_blocking($this->server_sock, 0); //设置事件监听,监听到服务器端socket可读,则有连接请求 event_set($this->server_event, $this->server_sock, EV_READ | EV_PERSIST, array($this,'ev_accept'), NULL); event_base_set($this->server_event, $this->base_event); event_add($this->server_event); event_base_loop($this->base_event); }
注意: 在设置事件监听上,第四个参数. 我使用 一个Array 来做. 在网上很多例子都是使用 function 名称. 但这样做不利于业务逻辑编写,所以,这里作出了一些修改.
下面为 ev_accept 方法的代码
[code=plain] private function ev_accept($server_socket, $events) { //接受连接 $accept_socket = @stream_socket_accept($server_socket); $accept_id = (int)$accept_socket; //增加socket timeout设定 stream_set_timeout($accept_socket, 2); @stream_set_blocking($accept_socket , 0); $accept_ip = @stream_socket_get_name($accept_socket, true); //新的事件监听,监听客户端发生的事件 $client_event = event_new(); event_set($client_event, $accept_socket, EV_READ | EV_PERSIST, array($this,'ev_read'), NULL); event_base_set($client_event,$this->base_event); event_add($client_event); //加入事件监听组 $this->client_sock[$accept_id] = $accept_socket; //加入到服务器端上客户端socket列表 $this->client_event[$accept_id] = $client_event; //加入到服务端上,客户端socket时间监听列表 }
注: 这个部分主要都是设定服务端接收一个Socket 连接的情况下, 服务端需要处理一些必要事情.如: 监听信息流事件,监听类型以及有信息流触发的处理方法. 这些事情都是对应每个Socket 来做相关处理.
下面为 ev_read 方法的代码
[code=language-php] private function ev_read($client_socket,$events){ $client_id = (int)$client_socket; $read = ''; $read = fread($client_socket, 2048)) if($read !== false && $read !=''){ //这里你就可以处理你读取的信息流 } else{ echo ' SOCKET CLOSE BY CLIENT ' ; //服务端释放对应用户的内存块 unset($this->client_sock[$client_id],$this->client_event[$client_id]); } }
展示的代码相对比较简单,但跌跌碰碰用了不少时间进行摸索.总的来讲,这样构建PHP 服务端会比用纯Socket组件要稳定.
相关文章推荐
- php基本知识复习--变量
- The logging tag can be at most 23 characters, was 28 (EnterpriseUnixFTPEntryParser) less... (Ctrl+F1
- 编译php扩展
- 黄永成-thinkphp讲解-个人博客讲解26集
- php如何修改二维数组子数组的键值
- FileOutputStream和FileInputStream实现文件的存储操作
- thinkphp3.x中cookie方法的用法分析
- thinkphp3.x中display方法及show方法的用法实例
- yii2安装过程记录
- thinkphp3.x连接mysql数据库的方法(具体操作步骤)
- php 字符串函数
- yii 如何使用 CWebLogRoute 记录和调试变量
- thinkphp3.x自定义Action、Model及View的简单实现方法
- thinkPHP实现递归循环栏目并按照树形结构无限极输出的方法
- 关于php跨域cookie共享使用方法
- mac上启用tftp服务器
- yii2 rbac权限管理学习笔记
- [PPTP] PPTP Server On Ubuntu With Double Public IP
- SCCM TP4创建边界和边界组
- 图解Zend studio破解方法及步骤