python websocket框架有哪些_Python Tornado框架实现websocket(http)异步协程

标签:

Tornado框架两行代码实现websocket(http)异步协程

Python作为解释型的脚本语言,开发效率高,所以非常适合用来做Web开发。而Python有上百种Web开发框架,我们最熟悉的莫过于:

Python 界最全能的Django,天生异步,性能强悍的 Tornado,微框架的典范Flask。

选择tornado更多的考量源于其单进程单线程异步IO的网络模式。高性能往往吸引人,可是很多人在实际中却往往感受不到。

增加两行代码,让你的程序性能飙升

class TestHandler(tornado.web.RequestHandler)

@tornado.gen.coroutine

def get(self, *args, **kwargs):

url = 'http://www.baidu.com'

response = yield tornado.httpclient.AsyncHTTPClient().fetch(url)

# python3.3之前需要使用下面语句返回

raise gen.Return(json_decode(response.body))

# python3.3 之后可以直接使用return语句

return self.wirte(json_decode(response.body))

代码完成后,如何测试效果呢?我们可以使用Apache的ab测试工具一下:

首先我们分别运行异步协程处理后的程序和没有异步协程的程序:

在程序运行时进入Apache目录下的bin文件夹,打开命令行(我使用的windows系统),输入如下命令:

-c 10一次产生的请求个数为10

-n 1000在测试会话中所执行的请求个数为1000次

-k http长连接

具体ab测试工具安装及使用大家可以百度一下,网上很多教程。

通过对比两次返回数据,很容易发现使用异步协程后程序的处理并发的性能有很大提升。

标签: