Workerman 高性能 PHP Socket 框架开源项目

我要开发同款
匿名用户2014年04月12日
102阅读

技术信息

开源地址
https://github.com/walkor/Workerman
授权协议
GPL

作品详情

Workerma是一个高性能的PHPsocket服务器框架,workerma基于PHP多进程以及libevet事件轮询库,PHP开发者只要实现一两个接口,便可以开发出自己的网络应用,例如Rpc服务、聊天室服务器、游戏服务器等。

Workerma的目标是让PHP开发者更容易的开发出基于socket的高性能的应用服务,而不用去了解PHPsocket以及PHP多进程细节。workerma本身是一个PHP多进程服务器框架,具有PHP进程管理以及socket通信的模块,所以不依赖php-fpm、gix或者apache等这些容器便可以独立运行。

特性

使用PHP开发

支持PHP多进程

支持TCP/UDP

接口上支持各种应用层协议

支持libevet事件轮询库,支持高并发

支持服务平滑重启

支持PHP文件更新检测及自动加载

支持PHP长连接

支持以指定用户运行子进程

支持telet远程控制

高性能

基于workerma已经有很多的网络应用程序,例例如多人在线小蝌蚪游戏、PHP-Jso-Rpc、PHP-Thrift-Rpc、PHP-WebSocket聊天室、PHP统计监控系统等等。

示例代码:

<?phpuse Workerma\Worker;require_oce './Workerma/Autoloader.php';// 创建一个Worker监听2346端口,使用websocket协议通讯$ws_worker = ew Worker("websocket://0.0.0.0:2346");// 启动4个进程对外提供服务$ws_worker->cout = 4;// 当收到客户端发来的数据后返回hello $data给客户端$ws_worker->oMessage = fuctio($coectio, $data){    // 向客户端发送hello $data    $coectio->sed('hello ' . $data);};// 运行Worker::ruAll();

性能压力测试

测试环境:

系统:ubutu 12.04 LTS 64位内存:8Gcpu:Itel® Core™ i3-3220 CPU @ 3.30GHz × 4

业务逻辑:

hello world

结果:

短链接(每次请求完成后关闭链接,下次请求建立新的链接):条件: 压测脚本开500个线程,每个线程链接Workerma 10W次,每次链接发送1个请求结果: 吞吐量:3W/S , cpu:60% , 内存占用:4*8M = 32M

 

长链接(每次请求后不关闭链接,下次请求继续复用这个链接):条件: 压测脚本开1000个线程,每个线程链接Workerma 1次,每个链接发送10W请求结果: 吞吐量:13W/S , cpu:68% , 内存占用:4*8M = 32M无流量抖动,无内存泄漏,性能非常强悍

workerma启动界面:

workerma状态查看界面:

功能介绍

Workerman 是一个高性能的PHP socket 服务器框架,workerman基于PHP多进程以及libevent事件轮询库,PHP开发者只要实现一两个接口,便可以开发出自己的网络应用,...

示例图片

声明:本文仅代表作者观点,不代表本站立场。如果侵犯到您的合法权益,请联系我们删除侵权资源!如果遇到资源链接失效,请您通过评论或工单的方式通知管理员。未经允许,不得转载,本站所有资源文章禁止商业使用运营!
下载安装【程序员客栈】APP
实时对接需求、及时收发消息、丰富的开放项目需求、随时随地查看项目状态

评论