FastAPI致力于实现轻便和快速,笔者很喜欢它,它的开发速度和简单程度令人欣慰。这对于端点特别有用,因为它们除了逻辑之外通常没有太多内容,而且很可能不需要Django或TurboGears等工具提供的所有无用信息来创建。
FastAPI也有非常好的文档,这让它变得易于学习。FastAPI中的“快”代表了开发api所需要的速度和这些api返回的速度。与其他web框架类似,它还基于API创建的开放标准,你可以在一个方便的包中获得传输数据所需的所有工具。
在语法方面,FastAPI采用一种非常类似于flass的方法来创建端点。
- from fastapi import FastAPI
- app = FastAPI()
- @app.get("/")
- async def root():
- return {"message":"Hello World"}
Tornado不仅是一个优秀的web框架,而且还是一个异步网络库,这让Tornado就能够为数以千计的开放连接服务。Tornado使用非阻塞网络进出流,使得它对于需要庞大且可伸缩的解决方案非常有用。
实际上,Tornado与大多数其他Python web框架有很大不同,它不在WSGI上运行。虽然这意味着在web服务器的选择上可能受到一些限制,但Tornado提供了预打包服务器,可以立即启动并运行。
虽然笔者很喜欢Tornado,但需要注意的是,当笔者尝试用NGINX部署它时确实遇到了很多bug。而且在某些情况下,让NGINX路由到正确的位置是并不是一件开心的事儿。笔者也遇到过Genie for Julia,不确定是什么原因造成的,但如果使用Tornado,那么最好设置一个Apache服务器,而不是NGINX服务器。
在语法方面,Tornado采用的是非常类似TurboGears的路由方法。使用Tornado时,通常会构建类来处理这些路由上的响应,而不是将逻辑放在路由中,来看看这个例子:
- import tornado.ioloop
- import tornado.web
- class MainHandler(tornado.web.RequestHandler):
- def get(self):
- self.write("Hello,world")
- def make_app():
- returntornado.web.Application([
- (r"/", MainHandler),
- ])
- if __name__ == "__main__":
- app = make_app()
- app.listen(8888)
- tornado.ioloop.IOLoop.current().start()