环境:64位Ubuntu14.04,i5-3230M
PHP5.4.31 with ZendOPcache
Node.JS 0.10.35
Node.JS 测试
var http = require('http');
http.createServer(function (req, res) {
res.writeHead(200, {'Content-Type': 'text/html;charset=UTF-8'});
res.write('
res.end();
}).listen(8082, '127.0.0.1');
运行程序:
node t.js
查看系统CPU空闲率:
sar 1
压力测试,并发100,完成10万请求:
ab -c100 -n100000 http://127.0.0.1:8082/
内存从11MB涨到61MB,系统CPU空闲率65%, RPS达到6049.
RPS即Requests per second,每秒处理的请求数,越大越好.
提示:点击图片,查看原图。
PHP CLI Server 测试
运行程序:
php -S 127.0.0.1:8081 -t ./
查看系统CPU空闲率:
sar 1
压力测试,并发100,完成10万请求:
ab -c100 -n100000 http://127.0.0.1:8081/t.php
内存从19.6MB涨到20.0MB,系统CPU空闲率57%, RPS达到11405.
不开启OPCACHE时,内存从8.3MB涨到9.0MB,系统CPU空闲率57%,RPS达到8851.
PHP Swoole 测试
set(\[ 'worker\_num' => 5 //开启5个工作进程 \]); $http->on('request', function (swoole\_http\_request $request, swoole\_http\_response $response) { $response->header('Content-Type', 'text/html;charset=UTF-8'); $response->end('测试: CPU空闲率在65%, RPS达到5140.
ab -c100 -n50000 http://127.0.0.1:8080/redis.php
2.Node.JS,使用npm install redis安装Redis客户端.
var redis = require('redis');
var client = redis.createClient('6379', '127.0.0.1');
var http = require('http');
http.createServer(function (req, res) {
res.writeHead(200, {'Content-Type': 'text/html;charset=UTF-8'});
res.write('
client.set("time_node", new Date().getTime(), function (err, reply) {
client.get("time_node");
});
res.end();
}).listen(8082, '127.0.0.1');
测试: CPU空闲率在65%, RPS达到5369.
ab -c100 -n50000 http://127.0.0.1:8082/
也就是说,就算在Apache老式的Prefork面前,Node.JS(RPS 5369)对比PHP(RPS 5140)的性能优势也不明显.别忘了,Apache还是一个经典的完备的HTTP服务器.