C10K问题的解决,涌现出一大批新框架,或者新语言,那么问题来了:到底谁最快呢?非专业程序猿来个非专业对比。

比较程序:输出Hello World!

测试程序:siege –c 100 –r 100 –b

例子包括:

1.go用http模块实现的helloworld

2.go用martini微框架实现的Helloworld

3.python3 python2 pypy分别用gevent server  tornado实现的Hello world

4.python3 python2 pypy分别用微框架bottle+gevent实现的Hello world

5.NodeJS纯JS实现的Helloworld

6.NodeJS用express框架实现的Helloworld

测试平台:

公司老旧的奔腾平台 Pentium(R) Dual-Core  CPU      E6700  @ 3.20GHz

内存2GB(够弱了吧)

先来宇宙最快的GO的测试:

  1 package main
2
3 import (
4 "fmt"
5 "net/http"
6 )
7
8 func sayhelloName(w http.ResponseWriter, r *http.Request){
9 fmt.Fprintf(w, "hello world!")
10 }
11
12 func main() {
13 http.HandleFunc("/", sayhelloName)
14 http.ListenAndServe(":9090", nil)
15 }

连续测试5次,成绩大体如下:

  1 Transactions:                  10000 hits
2 Availability: 100.00 %
3 Elapsed time: 4.11 secs
4 Data transferred: 0.11 MB
5 Response time: 0.03 secs
6 Transaction rate: 2433.09 trans/sec
7 Throughput: 0.03 MB/sec
8 Concurrency: 79.76
9 Successful transactions: 10000
10 Failed transactions: 0
11 Longest transaction: 0.20
12 Shortest transaction: 0.00

4.11秒,不错的成绩

再看NodeJS的例子:

  1 var http = require("http");
2 http.createServer(function(request, response) {
3 response.writeHead(200, {"Content-Type": "text/plain"});
4 response.write("Hello World!");
5 response.end();
6 }).listen(8000);
7 console.log("nodejs start listen 8888 port!");
8

测试结果如下:

  1 Transactions:                  10000 hits
2 Availability: 100.00 %
3 Elapsed time: 5.00 secs
4 Data transferred: 0.11 MB
5 Response time: 0.04 secs
6 Transaction rate: 2000.00 trans/sec
7 Throughput: 0.02 MB/sec
8 Concurrency: 86.84
9 Successful transactions: 10000
10 Failed transactions: 0
11 Longest transaction: 0.17
12 Shortest transaction: 0.00

5秒,比Go稍微慢一点

接下来是Python,由于python自带的wsgiref服务器,只是一个参考实现,性能很差,所以这里选用了两个性能不错的WSGI服务器gevent、tornado

gevent代码如下:

  1 #!/usr/bin/python
2 from gevent import pywsgi
3
4 def hello_world(env, start_response):
5 if env['PATH_INFO'] == '/':
6 start_response('200 OK', [('Content-Type', 'text/html')])
7 return ["hello world"]
8
9 print 'Serving on https://127.0.0.1:8000'
10 server = pywsgi.WSGIServer(('0.0.0.0', 8000), hello_world )
11 server.serve_forever()
12

tornado的代码如下:

  1 from tornado import httpserver
2 from tornado import ioloop
3 def handle_request(request):
4 if request.uri=='/':
5 message = b"Hello World!"
6 request.write(b"HTTP/1.1 200 OK\r\nContent-Length: %d\r\n\r\n%s" % (
7 len(message), message))
8 request.finish()
9
10 http_server = httpserver.HTTPServer(handle_request)
11 http_server.bind(8888)
12 http_server.start()
13 ioloop.IOLoop.instance().start()
14

由于python的例子要分别在python2 python3 pypy下跑,结果太多,我这里只给结果:

gevent:

python2:5.8秒,python3:7.5秒,pypy:4.8秒

有意思的是:pypy第一次跑用了6.8秒,第二次以后全是4.8秒(感觉原因是第一次由于jit浪费了一点时间)贴出某次pypy的成绩:

  1 Transactions:                  10000 hits
2 Availability: 100.00 %
3 Elapsed time: 4.77 secs
4 Data transferred: 0.10 MB
5 Response time: 0.04 secs
6 Transaction rate: 2096.44 trans/sec
7 Throughput: 0.02 MB/sec
8 Concurrency: 90.38
9 Successful transactions: 10000
10 Failed transactions: 0
11 Longest transaction: 0.13
12 Shortest transaction: 0.00
13

接下来是tornado:

python2:9.05秒,python3:8.6秒,pypy:5.95秒

同样:pypy第一次执行的时间为9.45秒,以后的每次只执行时间为5.9秒多一些

可以看出,pypy 与go nodejs性能相当,其中go最快为4.11秒,pypy+gevent与nodejs性能差不多,pypy稍好一点,pypy+tornado则稍慢于nodejs。

2。框架篇:

从上边例子可以看到,纯代码写起来还是比较麻烦的,一般我们都是用框架来写web,我选了几个轻量级的框架来输出helloworld:

go+martini

  1 package main
2
3 import "github.com/codegangsta/martini"
4
5 func main() {
6 m := martini.Classic()
7 m.Get("/", func() string {
8 return "Hello world!"
9 })
10 m.Run()
11 }
12

运行时间为:

  1 Transactions:                  10000 hits
2 Availability: 100.00 %
3 Elapsed time: 4.69 secs
4 Data transferred: 0.11 MB
5 Response time: 0.04 secs
6 Transaction rate: 2132.20 trans/sec
7 Throughput: 0.02 MB/sec
8 Concurrency: 90.23
9 Successful transactions: 10000
10 Failed transactions: 0
11 Longest transaction: 0.17
12 Shortest transaction: 0.00
13

nodejs+express:

  1 var express = require('express')
2 var app = express()
3
4 app.get('/', function (req, res) {
5 res.send('Hello World')
6 })
7
8 app.listen(3000)

用时:

  1 Transactions:                  10000 hits
2 Availability: 100.00 %
3 Elapsed time: 5.90 secs
4 Data transferred: 0.10 MB
5 Response time: 0.06 secs
6 Transaction rate: 1694.92 trans/sec
7 Throughput: 0.02 MB/sec
8 Concurrency: 96.44
9 Successful transactions: 10000
10 Failed transactions: 0
11 Longest transaction: 0.13
12 Shortest transaction: 0.01
13

python gevent+bottle:

  1 from gevent import monkey
2 monkey.patch_all()
3 from bottle import run,get
4
5 @get("/")
6 def index():
7 return "Hello world!"
8
9 run(server='gevent')
10

用时:python2 10.05秒,python3:12.95秒,pypy:5.85秒

python tornado:

  1 import tornado.httpserver
2 import tornado.ioloop
3 import tornado.web
4
5 class IndexHandler(tornado.web.RequestHandler):
6 def get(self):
7 self.write('Hello World!')
8
9 if __name__ == "__main__":
10 app = tornado.web.Application(handlers=[(r"/",IndexHandler)])
11 http_server = tornado.httpserver.HTTPServer(app)
12 http_server.listen(8000)
13 tornado.ioloop.IOLoop.instance().start()
14

用时:python2 11.85秒,python3:11.79秒,pypy:6.65秒

总结:可以看到,python在开启jit技术的pypy上web响应速度已经略优于nodejs,跟golang还有一定差距,但在同一数量级,标准python就稍微慢一些。

web编程速度大比拼(nodejs go python)(非专业对比)的更多相关文章

  1. python笔记之编程风格大比拼

    python笔记之编程风格大比拼 虽然我的python age并不高,但我仍然愿意将我遇到的或者我写的有趣的python程序和大家一块分享,下面是我找到的一篇关于各类python程序员的编程风格的比较 ...

  2. python web编程-概念预热篇

    互联网正在引发一场革命??不喜欢看概念的跳过,注意这里仅仅是一些从python核心编程一书的摘抄 这正是最激动人心的一部分了,web编程 Web 客户端和服务器端交互使用的“语言”,Web 交互的标准 ...

  3. Python 四大主流 Web 编程框架

    Python 四大主流 Web 编程框架 目前Python的网络编程框架已经多达几十个,逐个学习它们显然不现实.但这些框架在系统架构和运行环境中有很多共通之处,本文带领读者学习基于Python网络框架 ...

  4. 系列文章--Python Web编程

    我从网上找到了其他园友的文章,很不错,留着自己学习学习. Python Web编程(一)Python Web编程(二)Python Web编程(三)Python Web编程(四)Python Web编 ...

  5. python web编程 创建一个web服务器

    这里就介绍几个底层的用于创建web服务器的模块,其中最为主要的就是BaseHTTPServer,很多框架和web服务器就是在他们的基础上创建的 基础知识 要建立一个Web 服务,一个基本的服务器和一个 ...

  6. python web编程-web客户端编程

    web应用也遵循客户服务器架构 浏览器就是一个基本的web客户端,她实现两个基本功能,一个是从web服务器下载文件,另一个是渲染文件 同浏览器具有类似功能以实现简单的web客户端的模块式urllib以 ...

  7. python 教程 第十八章、 Web编程

    第十八章. Web编程 import urllib2 LOGIN = 'jin' PASSWD = 'Welcome' URL = 'https://tlv-tools-qc:8443/qcbin/s ...

  8. Python web编程 初识TCP UDP

    Python网络编程之初识TCP,UDP 这篇文章是读了<Python核心编程>第三版(Core Python Applications)的第二章网络编程后的自我总结. 如果有不到位或者错 ...

  9. Django,Flask,Tornado三大框架对比,Python几种主流框架,13个Python web框架比较,2018年Python web五大主流框架

    Django 与 Tornado 各自的优缺点Django优点: 大和全(重量级框架)自带orm,template,view 需要的功能也可以去找第三方的app注重高效开发全自动化的管理后台(只需要使 ...

随机推荐

  1. C# DataTable的用法

    建表DataTable dtP = new DataTable("Man");加列DataColumn dcP;dcP = new DataColumn("Name&qu ...

  2. 通过一个正则表达式,让SQL Server数据库的带参sql也支持位置参数语法!

    .NET Framework 2.0 中,Microsoft 在 System.Data.Common 名称空间下定义了一组类用来让程序员编写适用于不同数据库的数据访问代码,而且还在 Enterpri ...

  3. 后缀数组的一些性质----height数组

    height数组:定义 height[i] = suffix[i-1] 和 suffix[i] 的最长公共前缀,也就是排名相邻的两个后缀的最长公共前缀.那么对于 j 和 k 不妨设 Rank[j] & ...

  4. js操作cookie,js判断浏览器属性,

    在默认情况下,只有设置cookie的网页才能读取该cookie.如果想让一个页面读取另一个页面设置的cookie,必须设置cookie的路径. http://www.jb51.net/article/ ...

  5. MYSQL定时创建表分区

    MYSQL定时创建表分区 一.存储过程-表分区-----------------------------------------------------------------需求: 每月创建一个分区 ...

  6. –save与–save-dev

    使用npm install node_module –save自动更新dependencies字段值: 使用npm install node_module –save-dev自动更新devDepend ...

  7. Activiti5 待审 待批任务 TaskQuery查询 条件查询 like查询

    TaskQuery查询API 有两种方法可以从引擎中查询数据:查询API和原生查询.查询API提供了完全类型安全的API. 你可以为自己的查询条件添加很多条件 (所以条件都以AND组合)和精确的排序条 ...

  8. iOS下移除按钮原生样式

    按钮样式,在 Android 手机浏览器中显示正常,但在 iOS Safari 浏览器中会看到按钮显示为圆角样式,设置 border-radius:0; 也不好使. 这是因为iPhone.iPad 设 ...

  9. 通过innerHTML简化脚本

    <!doctype html> <html lang="en"> <head>   <meta charset="UTF-8&q ...

  10. Arduino当avr开发板

    原理并不复杂,因为arduino本来就是avr+一堆的库,找个能编译出hex的工具下载到板子就行. 但实际做起来还是碰到很多问题. 先是尝试eclipse+avr plugin 编译时出现make: ...