注:本文对于新版本的golang并不使用,go1以后go的性能已经有了比较好的提升,具体测试见:http://www.cnblogs.com/QLeelulu/archive/2012/08/12/2635261.html
听说Go是很不错的语言,了解了一下,一些特性确实很不错。
顺便测试了一下http与node.js的性能对比。
go的代码:
node.js的代码:
ab测试结果:
==** GO **==
$ ab -c 100 -n 1000 http://127.0.0.1:8080/ This is ApacheBench, Version 2.3<$Revision: 655654$> Server Software: Server Hostname: 127.0.0.1 Server Port: 8080 Document Path: / Document Length: 1 bytes Concurrency Level: 100 Time taken for tests: 0.322 seconds Complete requests: 1000 Failed requests: 0 Write errors: 0 Total transferred: 97000 bytes HTML transferred: 1000 bytes Requests per second: 3105.62 [#/sec] (mean) Time per request: 32.200 [ms] (mean) Time per request: 0.322 [ms] (mean, across all concurrent requests) Transfer rate: 294.18 [Kbytes/sec] received Connection Times (ms) min mean[+/-sd] median max Connect: 000.703 Processing: 13010.52955 Waiting: 13010.52955 Total: 43010.12955
==** Node.js **==
$ ab -c 100 -n 1000 http://127.0.0.1:8080/ This is ApacheBench, Version 2.3<$Revision: 655654$> Server Software: Server Hostname: 127.0.0.1 Server Port: 8080 Document Path: / Document Length: 12 bytes Concurrency Level: 100 Time taken for tests: 0.143 seconds Complete requests: 1000 Failed requests: 0 Write errors: 0 Total transferred: 50000 bytes HTML transferred: 12000 bytes Requests per second: 6993.50 [#/sec] (mean) Time per request: 14.299 [ms] (mean) Time per request: 0.143 [ms] (mean, across all concurrent requests) Transfer rate: 341.48 [Kbytes/sec] received Connection Times (ms) min mean[+/-sd] median max Connect: 001.104 Processing: 2136.61330 Waiting: 2136.61330 Total: 2146.41430
webbench测试结果
==** GO **==
$ webbench -t 30 -c 100 http://127.0.0.1:8080/ Webbench - Simple Web Benchmark 1.5 Copyright (c) Radim Kolar 1997-2004, GPL Open Source Software. Benchmarking: GET http://127.0.0.1:8080/ 100 clients, running 30 sec. Speed=146934 pages/min,262032 bytes/sec. Requests: 73467 susceed,0 Failed.
==** Node.js **==
$ webbench -t 30 -c 100 http://127.0.0.1:8080/ Webbench - Simple Web Benchmark 1.5 Copyright (c) Radim Kolar 1997-2004, running 30 sec. Speed=485128 pages/min,404273 bytes/sec. Requests: 242564 susceed,0 Failed.
从测试结果来看,node.js的HTTP SERVER性能是Go的两倍还多,而且让我比较郁闷的是,在用webbench进行测试的时候,可以看到go是用了我的笔记本上的四个核的cpu的,而node.js当然是只跑在一个核上,而Go居然还比node.js慢这么多。
然后我google,就看到:golang helloworld 45% slower than node.js
求真相!