2018年04月6日网站服务器迁移完成……

高性能的PHP socket 服务器框架 workerman

技术流 苏 demo 2268℃ 0评论

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

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

特性

  • 支持HHVM
  • 使用PHP开发
  • 支持PHP多进程/多线程(多线程版本)
  • 标准输入输出重定向
  • 守护进程化
  • 支持TCP/UDP
  • 支持多端口监听
  • 接口上支持各种应用层协议
  • 支持libevent事件轮询库,支持高并发
  • 支持服务平滑重启
  • 支持PHP文件更新检测及自动加载
  • 支持PHP长连接
  • 支持以指定用户运行子进程
  • 支持telnet远程控制
  • 高性能

查看更多 »

环境

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

安装

下载后解压即可

启动停止

启动:php start.php start -d

停止:php start.php stop

重启:php start.php restart

平滑重启:php start.php reload

查看状态:php start.php status

服务端开发示例EchoServer

1、新建文件Applications/Test/start.php

<?php
use Workerman\Worker;

// 创建一个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);
};

2、启动服务如下图:

php start.php start -d

1

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

php start.php status

2

性能

测试环境:

系统:ubuntu 12.04 LTS 64位
内存:8G
cpu:Intel® Core™ i3-3220 CPU @ 3.30GHz × 4

业务逻辑

EchoServer

结果

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

转载请注明:苏demo的别样人生 » 高性能的PHP socket 服务器框架 workerman

   如果本篇文章对您有帮助,欢迎向博主进行赞助,赞助时请写上您的用户名。
支付宝直接捐助帐号oracle_lee@qq.com 感谢支持!
喜欢 (0)or分享 (0)
发表我的评论
取消评论
表情