微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Workerman 特性 高性能 PHP socket 框架

程序名称:Workerman 特性

授权协议: GPL

操作系统: 跨平台

开发语言: PHP

Workerman 特性 介绍

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

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

特性

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

示例代码

<?PHP
use Workerman\Worker;
require_once './Workerman/Autoloader.PHP';

// 创建一个Worker监听2346端口,使用websocket协议通讯
$ws_worker = new Worker("websocket://0.0.0.0:2346");

// 启动4个进程对外提供服务
$ws_worker->count = 4;

// 当收到客户端发来的数据后返回hello $data给客户端
$ws_worker->onMessage = function($connection, $data)
{
    // 向客户端发送hello $data
    $connection->send('hello ' . $data);
};

// 运行
Worker::runAll();

性能压力测试

测试环境:

系统:ubuntu 12.04 LTS 64位
内存:8G
cpu: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状态查看界面:


Workerman 特性 官网

http://www.workerman.net/

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐