WorkerMan源码分析 - 实现最简单的原型文章中提到了libevent网络库,前者和libev都是事件驱动编程库高性能。简单说libev对libevent做了改进和精简。libevent使用全局变量,导致非线程安全。它的watcher结构也过大,把I/O、计时器、信号句柄整合在一起。而且(作者认为)libevent的附加组件如http和dns库都实现不好,且有安全问题。libev对这些地方做了改进,避免使用全局变量,拆分watcher等。另外libev去掉了外部库(比如http和dns),只专注于事件驱动服务,所以更精简。

安装libev扩展

地址:https://pecl.php.net/package/ev

实例

定时器实现

<?php
//定时器的实现,2秒后每2秒触发1次注册的事件 $loop = new EvLoop(); function timers()
{
echo date("Y-m-d H:i:s") . "\n";
} //$event = $loop->timer(2,0,'timers');
$event = $loop->timer(2,2,'timers');
$loop->run();

结果如下:

2018-04-25 16:57:54
2018-04-25 16:57:55
2018-04-25 16:57:56
2018-04-25 16:57:57

基于事件循环 异步io 的socket读写

 <?php
$loop = new EvLoop();
$arr = [];
$data = "hello world\n"; function add($fd,$ev,$func){
global $arr,$loop;
$func = getStreamListenerClosure($fd,$func);
//创建观察者监听io $ev事件
$event = $loop->io($fd,$ev,$func);
$arr[posix_getpid()][(int)$fd] = $event;
} //返回闭包
function getStreamListenerClosure($stream, $listener){
return function () use ($stream,$listener){
call_user_func($listener,$stream);
};
} //读
function baseRead($socket){
$buffer = @fread($socket, 2); if ($buffer == "\n"){
//结尾
fclose($socket) && removeStream($socket);
} else {
echo $buffer;
}
} //写
function baseWrite($socket){ global $data; $written = fwrite($socket, $data,1);
if ($written === strlen($data)) {
fclose($socket);
removeStream($socket);
} else {
$data = substr($data, $written);
} } //停止指定事件并销魂指定流资源
function removeStream($stream){ global $arr,$loop;
$key = (int)$stream;
$pid = posix_getpid(); if (!isset($arr[$pid][$key]))
return; $arr[$pid][$key]->stop();
unset($arr[$pid][$key]);
} function acceptConnection($socket){ $new_socket = @stream_socket_accept($socket);
if (!$new_socket) {
return;
} stream_set_blocking($new_socket,false);
stream_set_read_buffer($new_socket, 0); //add($new_socket,Ev::READ,'baseRead');
add($new_socket,Ev::WRITE,'baseWrite'); } //定时器
function timers()
{
echo date("Y-m-d H:i:s") . "\n";
} $socketmain = stream_socket_server('tcp://127.0.0.1:7777');
//非阻塞
stream_set_blocking($socketmain,false); add($socketmain,Ev::READ,'acceptConnection'); $event = $loop->timer(2,2,'timers'); $loop->run(); /*
while (true){
//EV::RUN_ONCE 事件只触发1次
$loop->run(EV::RUN_ONCE);
}
*/

利用telnet测试,具体参考WorkerMan源码分析 - 实现最简单的原型文章。

php libev扩展使用的更多相关文章

  1. 使用 libevent 和 libev 提高网络应用性能——I/O模型演进变化史

    构建现代的服务器应用程序需要以某种方法同时接收数百.数千甚至数万个事件,无论它们是内部请求还是网络连接,都要有效地处理它们的操作. 有许多解决方案,但事件驱动也被广泛应用到网络编程中.并大规模部署在高 ...

  2. 使用 libevent 和 libev 提高网络应用性能

    使用 libevent 和 libev 提高网络应用性能 Martin C. Brown, 作家, Freelance 简介: 构建现代的服务器应用程序需要以某种方法同时接收数百.数千甚至数万个事件, ...

  3. [转]Libev源码分析 -- 整体设计

    Libev源码分析 -- 整体设计 libev是Marc Lehmann用C写的高性能事件循环库.通过libev,可以灵活地把各种事件组织管理起来,如:时钟.io.信号等.libev在业界内也是广受好 ...

  4. libev中timer时间事件监控器

    1.数据结构 #define ev_at(w) ((WT)(w))->at#define ev_active(w) ((W)(w))->active typedef ev_watcher_ ...

  5. 使用 Passenger +Apache扩展 Puppet,代替其Webrick的web框架

    使用 Passenger +Apache扩展 Puppet,代替其Webrick的web框架 1安装 yum install ruby-devel ruby-libs rubygems libcurl ...

  6. 开源网络库ACE、Boost的ASIO、libevent、libev、ZeroMQ

    开源C/C++网络库:ACE          C++语言 跨平台Boost的ASIO  C++语言 跨平台libevent     C语言   主要支持linux,新版增加了对windows的IOC ...

  7. libev整体设计

    转自:http://m.blog.csdn.NET/blog/weiqubo/16355653 libev是Marc Lehmann用C写的高性能事件循环库.通过libev,可以灵活地把各种事件组织管 ...

  8. Asp.net Boilerplate之AbpSession扩展

    当前Abp版本1.2,项目类型为MVC5. 以属性的形式扩展AbpSession,并在"记住我"后,下次自动登录也能获取到扩展属性的值,版权归"角落的白板报"所 ...

  9. 恢复SQL Server被误删除的数据(再扩展)

    恢复SQL Server被误删除的数据(再扩展) 大家对本人之前的文章<恢复SQL Server被误删除的数据> 反应非常热烈,但是文章里的存储过程不能实现对备份出来的日志备份里所删数据的 ...

随机推荐

  1. 1047A_Little C Loves 3 I(构造)

    A. Little C Loves 3 I time limit per test 1 second memory limit per test 256 megabytes input standar ...

  2. Linux命令:unzip

    语法: unzip [-Z] [-opts[modifiers]] file[.zip] [list] [-x xlist] [-d exdir] 默认行为将zip文件中的内容全部解压缩到当前目录下. ...

  3. Zabbix笔记

    简单检查中的icmppingloss[<target>,<packets>,<interval>,<size>,<timeout>]   结 ...

  4. 焊接关节(Weld Joint)

    package{ import Box2D.Common.Math.b2Vec2; import Box2D.Dynamics.b2Body; import Box2D.Dynamics.Joints ...

  5. linux 3.10 gro的理解和改进

    gro,将同一个flow的一定时间范围之内的skb进行合并,减少协议栈的消耗,用于收包性能提升.gro网上的资料很多,但是都很少谈到gro的改进,刚好身边有个同事也想改这块的内容, 所以将最近看的gr ...

  6. RabbitMQ.Net 应用(1)

    风浪子 概述 MQ全称为Message Queue, 消息队列(MQ)是一种应用程序对应用程序的通信方法.RabbitMQ是一个在AMQP基础上完整的,可复用的企业消息系统.他遵循Mozilla Pu ...

  7. delphi注册热键方法(一)

    uses windows,menus; ..... //声明 HotKey_Key: Word; HotKey_Shift: Word; procedure WMHotKey(var msg : Tm ...

  8. hibernate中的sql 1+n 问题

    ( 产生的原因:当一对多或多对多的映射关系下,当在一方添加或修改数据时,一方集合属性中的多方都要发生变化;先select语句,再update语句.当一方集合属性中的数据有很多时,对应的update语句 ...

  9. Applese的毒气炸弹-最小生成树Kruskal算法

    链接:https://ac.nowcoder.com/acm/contest/330/G来源:牛客网 题目描述 众所周知,Applese 是个很强的选手,它的化学一定很好. 今天他又AK了一套题觉得很 ...

  10. Java8 parallelStream与迭代器Iterator性能

    定义一个测试类 public class TestParallelStream { private List<Integer> list; private int size; privat ...