您的位置:首页 > 其它

试试博客

2016-04-29 15:21 232 查看
从tornado自带的helloword例子出发:

import tornado.httpserver
import tornado.ioloop
import tornado.options
import tornado.web

from tornado.options import define, options

define("port", default=8888, help="run on the given port", type=int)

class MainHandler(tornado.web.RequestHandler):
def get(self):
self.write("Hello, world")

def main():
tornado.options.parse_command_line()
application = tornado.web.Application([
(r"/", MainHandler),
])
http_server = tornado.httpserver.HTTPServer(application)
http_server.listen(options.port)
tornado.ioloop.IOLoop.current().start()

if __name__ == "__main__":
main()


上面的例子构造了一个最简单的基于tornado的helloworld的web服务器:用户访问8888端口得到helloworld的反馈。那么在这个过程中,tornado到底做了哪些工作呢,它的异步架构是怎么得到体现的呢?

从大的层面上看,构造上述tornado的web服务器使用了4个元素: RequestHandler, Application, HTTPServer和ioloop. 了解服务器的同学应该能够猜到它们之间的关系了:HTTPServer提供了面向client的web服务,Application将client的访问路由到具体的RequestHandler,ioloop提供tornado中的事件监控调度。

从main函数当中开始看起:

application = tornado.web.Application([
(r"/", MainHandler),
])


首先实例化了一个Application对象,传入的参数是一个tuple。url是一个字符串,MainHandler是RequestHandler的子类,它实现了其中的get方法,该方法的定义是:

def get(self, *args, **kwargs):
raise HTTPError(405)

(所以如果你没有实现这个方法而直接使用的话是会直接报405错误的,这个技巧到时可以在写框架类的时候用到)。言归正传,get方法中什么都不干,直接向client发送“Hello, world”。

而在application中,参数是一个list,所以我们可以定义多个(url, handler)的tuple对。正如代码中对application的定义:一组request handler构成了一个application。

再来看看Application对传入的handler都做了什么:

if handlers:
self.add_handlers(".*$", handlers)
所以它维护了一个包含了一个或者多个handlers的字典,url是key,value是handler。

然后是初始化了一个httpserver:

http_server = tornado.httpserver.HTTPServer(application)
HttpServer继承了TcpServer类,来处理由tcp数据接收到handler处理的流程。

监听端口:

http_server.listen(options.port)
最后启动ioloop,直接看代码中的死循环了:

while True:
event_pairs = self._impl.poll(poll_timeout)
self._events.update(event_pairs)
while self._events:
fd, events = self._events.popitem()
fd_obj, handler_func = self._handlers[fd]
handler_func(fd_obj, events)

删除一些代码后,可以看到每隔timeout时间会poll出event出来到events中,然后对event进行处理,这里的_handler[fd]来进行处理,这里是handler是对该fd的读写操作。

晕死,写的乱七八糟的。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: