軟件簡(jiǎn)介
Workerman 是一個(gè)高性能的 PHP socket 服務(wù)器框架,workerman 基于 PHP 多進(jìn)程以及 libevent 事件輪詢庫(kù),PHP 開(kāi)發(fā)者只要實(shí)現(xiàn)一兩個(gè)接口,便可以開(kāi)發(fā)出自己的網(wǎng)絡(luò)應(yīng)用,例如 Rpc 服務(wù)、聊天室服務(wù)器、游戲服務(wù)器等。
Workerman 的目標(biāo)是讓 PHP 開(kāi)發(fā)者更容易的開(kāi)發(fā)出基于 socket 的高性能的應(yīng)用服務(wù),而不用去了解 PHP socket 以及 PHP 多進(jìn)程細(xì)節(jié)。 workerman 本身是一個(gè) PHP 多進(jìn)程服務(wù)器框架,具有 PHP 進(jìn)程管理以及 socket 通信的模塊,所以不依賴(lài) php-fpm、nginx 或者 apache 等這些容器便可以獨(dú)立運(yùn)行。
特性
- 使用 PHP 開(kāi)發(fā)
- 支持 PHP 多進(jìn)程
- 支持 TCP/UDP
- 接口上支持各種應(yīng)用層協(xié)議
- 支持 libevent 事件輪詢庫(kù),支持高并發(fā)
- 支持服務(wù)平滑重啟
- 支持 PHP 文件更新檢測(cè)及自動(dòng)加載
- 支持 PHP 長(zhǎng)連接
- 支持以指定用戶運(yùn)行子進(jìn)程
- 支持 telnet 遠(yuǎn)程控制
- 高性能
基于 workerman 已經(jīng)有很多的網(wǎng)絡(luò)應(yīng)用程序
示例代碼:
<?php
use Workerman\Worker;
require_once './Workerman/Autoloader.php';
// 創(chuàng)建一個(gè)Worker監(jiān)聽(tīng)2346端口,使用websocket協(xié)議通訊
$ws_worker = new Worker("websocket://0.0.0.0:2346");
// 啟動(dòng)4個(gè)進(jìn)程對(duì)外提供服務(wù)
$ws_worker->count = 4;
// 當(dāng)收到客戶端發(fā)來(lái)的數(shù)據(jù)后返回hello $data給客戶端
$ws_worker->onMessage = function($connection, $data)
{
// 向客戶端發(fā)送hello $data
$connection->send('hello ' . $data);
};
// 運(yùn)行
Worker::runAll();
性能壓力測(cè)試
測(cè)試環(huán)境:
系統(tǒng):ubuntu 12.04 LTS 64位
內(nèi)存:8G
cpu:Intel? Core? i3-3220 CPU @ 3.30GHz × 4
業(yè)務(wù)邏輯:
hello world
結(jié)果:
短鏈接(每次請(qǐng)求完成后關(guān)閉鏈接,下次請(qǐng)求建立新的鏈接):
條件: 壓測(cè)腳本開(kāi)500個(gè)線程,每個(gè)線程鏈接Workerman 10W次,每次鏈接發(fā)送1個(gè)請(qǐng)求
結(jié)果: 吞吐量:3W/S , cpu:60% , 內(nèi)存占用:4*8M = 32M
長(zhǎng)鏈接(每次請(qǐng)求后不關(guān)閉鏈接,下次請(qǐng)求繼續(xù)復(fù)用這個(gè)鏈接):
條件: 壓測(cè)腳本開(kāi)1000個(gè)線程,每個(gè)線程鏈接Workerman 1次,每個(gè)鏈接發(fā)送10W請(qǐng)求
結(jié)果: 吞吐量:13W/S , cpu:68% , 內(nèi)存占用:4*8M = 32M
無(wú)流量抖動(dòng),無(wú)內(nèi)存泄漏,性能非常強(qiáng)悍
workerman 啟動(dòng)界面:
workerman 狀態(tài)查看界面: