PHP, Node.js, Golang 随机 IO 性能测试
今天不上班, 我来水一贴
环境
- OS: Ubuntu16.04LTS 2C4T 4G RAM
- PHP7.2原生代码
- Node.js v8.9.1LTS Fastify
- Golang1.9 Gin
代码很简单, 我就只上PHP的好了
<?php
phpinfo();
$db = new mysqli('192.168.1.154', 'root', 'lxz', 'test');
$id = mt_rand(1, 1000);
$data = $db->query("select * from foo where id = {$id}")->fetch_row();
echo json_encode([
'id' => $data[0],
'uuid' => $data[1]
]);
测试结果
ab -c 100 -n 10000 http://127.0.0.1:8080/
Node.js 1863 2494 2685 2615 2510
PHP 1158 1262 1206 1287 1210
Go 2145 2631 2107 (连接数太多直接挂了) 2214
结论
- MySQL IO性能: Node.js > Go > PHP
- 开发效率和可维护性: PHP > Node.js >> Go
- 稳定性和成熟性: PHP > Node.js > Go
- 社区活跃度: Node.js > PHP > Go
- 招聘难度: PHP < Node.js < Go (在下认为很多脚本语言转Go的人都很不靠谱, 非常容易写出辣鸡代码)
推荐文章: