在安装前大概介绍下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 virtualenvvirtualenv tornadocd tornadosh bin/activate
这时显示为:
(tornado)? ~VIRTUAL_ENV >
开始安装tornado
pip install tornado
新建项目目录
mkdir tornado_democd tornado_demo
Hello Tornado
新建hello.py 文件,输入以下内容
import tornado.httpserverimport tornado.ioloopimport tornado.optionsimport tornado.webfrom tornado.options import define, optionsdefine("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搭建成功,如果想看更详细的内容,可以点击这里
参考链接Tornado 主页Tornado 中国镜像站点GitHub Project PageTornado Google GroupIntroduction to Tornado