PHP, Node.js, Golang 随机 IO 性能测试

分享 李曦赞 ⋅ 于 4周前 ⋅ 最后回复由 李曦赞 5天前 ⋅ 357 阅读

今天不上班, 我来水一贴

环境
  • 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的人都很不靠谱, 非常容易写出辣鸡代码)
回复数量: 9
  • 李曦赞
    4周前

    可怕, Node.js加了连接池跑出4000的成绩了

  • Littlesqx 癞蛤蟆想吃炖大鹅
    4周前

    @李曦赞 Golang 也可以加连接池啊...顺便也加上 Swoole 的测试呗, Swoole 也可以连接池。还有,其他语言的代码也贴出来呗

  • tccbest
    4周前

    抛开业务谈性能没意义

  • 李曦赞
    4周前

    @Littlesqx 改天试试Swoole

  • 李曦赞
    4周前

    @tccbest 业务场景就是IO密集型

  • xuanjiang1985 人生苦短,用脚本语言。
    4周前

    数据库往往有个中间层

  • Aaron 真诚、爱laravel,爱php!
    4周前

    感觉没可比性吧。 node 本来就是异步回调机制,而 php 是同步阻塞。 楼主觉得还用比吗?

  • 李曦赞
    5天前

    @Littlesqx Golang加连接池跑到4800了, 多核性能很强

  • 李曦赞
    5天前

    @Aaron 我就想看看差距多大

暂无评论~~

  请勿发布不友善或者负能量的内容。与人为善,比聪明更重要!