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等这些容器便可以独立运行。


下载

下载workerman

   下载160558次

特性

支持HHVM

使用PHP开发

支持PHP多进程/多线程(多线程版本)

标准输入输出重定向

支持毫秒定时器

支持基于事件的异步编程

守护进程化

支持TCP/UDP

支持多端口监听

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

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

支持服务平滑重启

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

支持PHP长连接

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

支持telnet远程控制

高性能

workerman相关应用

vmstat服务器状态监控服务

WEB消息推送框架

BrowserQuest PHP版本

摄像头视频直播

Thrift RPC 远程调用框架

Json RPC远程调用框架

聊天室框架

统计监控系统

PHP小蝌蚪实时交互游戏  hot

flappy bird 多人在线版游戏

环境

PHP>=5.3 非Win系统  详细安装教程点击这里


Windows 用户点击这里


安装

下载后解压即可


服务端开发示例WebSocket Server

1、新建文件start.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();


 

2、启动服务类似下图:

php start.php start -d


workerman启动界面

3、查看workerman运行状态类似如下界面:

php start.php status


workerman 查看运行状态

性能

测试环境:

系统:ubuntu 12.04 LTS 64位

内存:8G

cpu:Intel® Core™ i3-3220 CPU @ 3.30GHz × 4


<?php

use Workerman\Worker;

$worker = new Worker('tcp://0.0.0.0:1234');

$worker->count=3;

$worker->onMessage = function($connection, $data)

{

    // 长连接

    $connection->send("HTTP/1.1 200 OK\r\nConnection: keep-alive\r\nServer: workerman\1.1.4\r\n\r\nhello");

    // 短连接

    //$connection->close("HTTP/1.1 200 OK\r\nServer: workerman\1.1.4\r\n\r\nhello");

};

Worker::runAll();


业务逻辑

EchoServer

结果

短链接(每次请求完成后关闭链接,下次请求建立新的链接):

条件: 压测脚本开500个线程,每个线程链接Workerman 10W次,每次链接发送1个请求

结果: 吞吐量:3W/S , cpu:60% , 内存占用:4*8M = 32M

长链接(每次请求后不关闭链接,下次请求继续复用这个链接):

条件: 压测脚本开1000个线程,每个线程链接Workerman 1次,每个链接发送10W请求

结果: 吞吐量:15.6W/S , cpu:68% , 内存占用:4*8M = 32M


有话要说