您好,欢迎访问一九零五行业门户网

Workerman -- 高性能的 PHP socket 框架

workerman 是一个高性能的php socket 服务器框架,workerman基于php多进程以及libevent事件轮询库,php开发者只要实现一两个接口,便可以开发出自己的网络应用,例如rpc服务、聊天室服务器、游戏服务器等。
workerman 的目标是让php开发者更容易的开发出基于socket的高性能的应用服务,而不用去了解php socket以及php多进程细节。 workerman本身是一个php多进程服务器框架,具有php进程管理以及socket通信的模块,所以不依赖php-fpm、nginx或者apache等这些容器便可以独立运行。
特性 使用php开发
支持php多进程
支持tcp/udp
接口上支持各种应用层协议
支持libevent事件轮询库,支持高并发
支持服务平滑重启
支持php文件更新检测及自动加载
支持php长连接
支持以指定用户运行子进程
支持telnet远程控制
高性能
基于workerman已经有很多的网络应用程序,例例如 多人在线小蝌蚪游戏 、 php-json-rpc 、 php-thrift-rpc 、 php-websocket聊天室 、 php统计监控系统 等等。
示例代码:
count = 4;// 当收到客户端发来的数据后返回hello $data给客户端$ws_worker->onmessage = function($connection, $data){ // 向客户端发送hello $data $connection->send('hello ' . $data);};// 运行worker::runall();
性能压力测试
测试环境:
系统:ubuntu 12.04 lts 64位内存:8gcpu:intel® core™ i3-3220 cpu @ 3.30ghz × 4
业务逻辑: hello world
结果: 短链接(每次请求完成后关闭链接,下次请求建立新的链接):条件: 压测脚本开500个线程,每个线程链接workerman 10w次,每次链接发送1个请求结果: 吞吐量:3w/s , cpu:60% , 内存占用:4*8m = 32m
长链接(每次请求后不关闭链接,下次请求继续复用这个链接):条件: 压测脚本开1000个线程,每个线程链接workerman 1次,每个链接发送10w请求结果: 吞吐量:13w/s , cpu:68% , 内存占用:4*8m = 32m
无流量抖动,无内存泄漏,性能非常强悍
workerman启动界面:
workerman状态查看界面:
其它类似信息

推荐信息