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系统),输入如下命令:
ab -c 10 -n 1000 -k http://127.0.0.1:8888/test
-c 10一次产生的请求个数为10
-n 1000在测试会话中所执行的请求个数为1000次
-k http长连接
具体ab测试工具安装及使用大家可以百度一下,网上很多教程。