## Overview
[FriendFeed](http://friendfeed.com/)使用了一款使用 Python 編寫的,相對簡單的 非阻塞式 Web 服務器。其應用程序使用的 Web 框架看起來有些像 [web.py](http://webpy.org/) 或者 Google 的 [webapp](http://code.google.com/appengine/docs/python/tools/webapp/), 不過為了能有效利用非阻塞式服務器環境,這個 Web 框架還包含了一些相關的有用工具 和優化。
[Tornado](http://sebug.net/paper/books/tornado/) 就是我們在 FriendFeed 的 Web 服務器及其常用工具的開源版本。Tornado 和現在的主流 Web 服務器框架(包括大多數 Python 的框架)有著明顯的區別:它是非阻塞式服務器,而且速度相當快。得利于其 非阻塞的方式和對 [epoll](http://www.kernel.org/doc/man-pages/online/pages/man4/epoll.4.html) 的運用,Tornado 每秒可以處理數以千計的連接,因此 Tornado 是實時 Web 服務的一個 理想框架。我們開發這個 Web 服務器的主要目的就是為了處理 FriendFeed 的實時功能 ——在 FriendFeed 的應用里每一個活動用戶都會保持著一個服務器連接。(關于如何擴容 服務器,以處理數以千計的客戶端的連接的問題,請參閱 [The C10K problem](http://www.kegel.com/c10k.html) )
以下是經典的 “Hello, world” 示例:
```
import tornado.ioloop
import tornado.web
class MainHandler(tornado.web.RequestHandler):
def get(self):
self.write("Hello, world")
application = tornado.web.Application([
(r"/", MainHandler),
])
if __name__ == "__main__":
application.listen(8888)
tornado.ioloop.IOLoop.instance().start()
```
查看下面的 [Tornado 攻略](#tornado-walkthrough)以了解更多關于 `tornado.web` 包 的細節。
我們清理了 Tornado 的基礎代碼,減少了各模塊之間的相互依存關系,所以理論上講, 你可以在自己的項目中獨立地使用任何模塊,而不需要使用整個包。