【tornado】1.创建http服务器

本文介绍了Tornado Web框架的基础使用,包括如何创建基本的HTTP服务器,以及如何通过bind和start方法启用多进程,提高服务器处理能力。
1.介绍一个基础框架:
import tornado.web
import tornado.ioloop

class IndexHandler(tornado.web.RequestHandler):
    # IndexHandler只能接收get方法,不能接收post方法
    def get(self):
        self.write("test")

if __name__=="__main__":
    # Application是tornado的核心应用类
    # app里面保存了路由映射表,同时有一个listen方法可以用于创建http服务器的实例
    app=tornado.web.Application([
        (r"/",IndexHandler)
    ])
    # 此行创建了一个服务器,并绑定了一个端口,但是没有开启此服务器
    app.listen(8000)
    # current()返回当前线程的IOLoop实例
    # start()启动循环,开启监听
    tornado.ioloop.IOLoop.current().start()

2.如何显式地创建一个服务器:
import tornado.web
import tornado.ioloop
import tornado.httpserver  #需要引入httpserver模块

class IndexHandler(tornado.web.RequestHandler):
    def get(self):
        self.write("test")

if __name__=="__main__":
    app=tornado.web.Application([
        (r"/",IndexHandler)
    ])
    # 创建一个服务器,服务器使用的路由映射表信息来自app
    httpServer=tornado.httpserver.HTTPServer(app)
    httpServer.listen(8000)
    tornado.ioloop.IOLoop.current().start()
  • tornado的web应用对象app的listen和服务器的listen不是同一个listen,因为它们属于不同的类,是不同的方法
  • 第一段代码和第二段代码实质是一样的,只是第二段代码可以体验实际创建一个服务器的过程。

3.服务器启用多进程:
import tornado.web
import tornado.ioloop
import tornado.httpserver

class IndexHandler(tornado.web.RequestHandler):
    def get(self):
        self.write("test")

if __name__=="__main__":
    app=tornado.web.Application([
        (r"/",IndexHandler)
    ])
    httpServer=tornado.httpserver.HTTPServer(app)
    # httpServer.listen(8000)

    httpServer.bind(8000)
    httpServer.start(5)

    tornado.ioloop.IOLoop.current().start()
  • 首先如果要使用多进程就不能直接用服务器listen一个窗口了(listen只能在单进程模式中使用)
  • 多进程要改用bind+start方法。其中start方法中的数字是最高进程数(默认是1个)
  • 不建议直接启动多进程,而是使用手动创建子进程的方式,同时手动启动多个进程还可以绑定不同的端口
### Tornado Web Framework 中的 HTTP 处理 Tornado 是一个应用程序开发框架和网络库,设计用于处理异步操作,允许服务器维护大量打开连接[^1]。对于 HTTP 请求的处理,Tornado 提供了一套完整的工具集来管理请求和响应。 #### 创建 HTTP 服务器 为了创建一个基本的 HTTP 服务器,在 Tornado 应用程序中通常会定义 `RequestHandler` 类并重写其方法: ```python import tornado.ioloop import tornado.web class MainHandler(tornado.web.RequestHandler): def get(self): self.write("Hello, world") def make_app(): return tornado.web.Application([ (r"/", MainHandler), ]) if __name__ == "__main__": app = make_app() app.listen(8888) tornado.ioloop.IOLoop.current().start() ``` 这段代码展示了如何设置一个简单的 HTTP 服务端口监听,并返回固定的字符串作为回应[^2]。 #### 错误处理机制 当遇到错误情况时,可以通过捕获异常或者自定义状态码来进行更优雅地处理。例如,如果资源未找到,则可以发送 404 响应;而对于内部服务器错误则应该给出 5xx 的系列编码之一。下面是一个例子说明怎样实现这一点: ```python from http import HTTPStatus class ErrorHandler(tornado.web.RequestHandler): def prepare(self): super().prepare() # 如果路径不存在于路由表里就抛出 Not Found Exception raise tornado.web.HTTPError(HTTPStatus.NOT_FOUND) def write_error(self, status_code, **kwargs): self.set_header('Content-Type', 'application/json') response_data = { "status": False, "message": f"{self._reason}" } self.finish(response_data) ``` 此部分实现了对未知 URL 路径自动回复 JSON 格式的错误消息的功能[^3]。 #### 测试脚本的应用 测试是确保应用稳定性的关键环节。通过编写单元测试案例可以帮助发现潜在的问题所在。这里提供了一个简单的测试样例链接,可用于参考构建自己的自动化测试流程。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值