在安装前大概介绍下tornado
由来
Tornado全称Tornado Web Server,是一个用Python语言写成的Web服务器兼Web应用框架,由FriendFeed公司在自己的网站FriendFeed中使用,被Facebook收购以后框架以开源软件形式开放给大众。
Tornado 是 FriendFeed 使用的可扩展的非阻塞式 web 服务器及其相关工具的开源版本。这个 Web 框架看起来有些像 web.py 或者 Google 的 webapp,不过为了能有效利用非阻塞式服务器环境,这个 Web 框架还包含了一些相关的有用工具 和优化。
Tornado 和现在的主流 Web 服务器框架(包括大多数 Python 的框架)有着明显的区别:它是非阻塞式服务器,而且速度相当快。得利于其 非阻塞的方式和对 epoll 的运用,Tornado 每秒可以处理数以千计的连接,这意味着对于实时 Web 服务来说,Tornado 是一个理想的 Web 框架。我们开发这个 Web 服务器的主要目的就是为了处理 FriendFeed 的实时功能 ——在 FriendFeed 的应用里每一个活动用户都会保持着一个服务器连接。(关于如何扩容 服务器,以处理数以千计的客户端的连接的问题,请参阅 C10K problem。)
特点
- 作为Web框架,是一个轻量级的Web框架,类似于另一个Python web 框架Web.py,其拥有异步非阻塞IO的处理方式。
- 作为Web服务器,Tornado有较为出色的抗负载能力,官方用nginx反向代理的方式部署Tornado和其它Python web应用框架进行对比,结果最大浏览量超过第二名近40%。
性能
Tornado有着优异的性能。它试图解决C10k问题,即处理大于或等于一万的并发,下表是和一些其他Web框架与服务器的对比:
处理器为 AMD Opteron, 主频2.4GHz, 4核
| 服务 | 部署 | 请求/每秒 | ||||
| Tornado | nginx, 4进程 | 8213 | ||||
| Tornado | 1个单线程进程 | 3353 | ||||
| Django | Apache/mod_wsgi | 2223 | ||||
| web.py | Apache/mod_wsgi | 2066 | ||||
| CherryPy | 独立 | 785 |
安装
为了不影响当前操作系统的python环境,我还是选择通过virtualenv 来部署安装tornado
pip install virtualenv
virtualenv tornado
cd tornado
sh bin/activate
这时显示为:
(tornado)➜ ~VIRTUAL_ENV >
开始安装tornado
pip install tornado
新建项目目录
mkdir tornado_demo
cd tornado_demo
Hello Tornado
新建hello.py 文件,输入以下内容
import tornado.httpserver
import tornado.ioloop
import tornado.options
import tornado.web
from tornado.options import define, options
define("port", default=8000, help="run on the given port", type=int)
class IndexHandler(tornado.web.RequestHandler):
def get(self):
self.write('Hello, Tornado!')
if __name__ == "__main__":
tornado.options.parse_command_line()
app = tornado.web.Application(handlers=[(r"/", IndexHandler)])
http_server = tornado.httpserver.HTTPServer(app)
http_server.listen(options.port)
tornado.ioloop.IOLoop.instance().start()
运行
你可以在命令行里尝试运行这个程序以测试输出:
python hello.py --port=8000
现在你可以在浏览器中打开http://localhost:8000,或者打开另一个终端窗口使用curl测试我们的应用:
$ curl http://localhost:8000/
Hello, Tornado!
到此说明tornado搭建成功,如果想看更详细的内容,可以点击这里