6-tornado配置文件的使用(命令行解析、文件设置)

tornado.options

python 复制代码
options 可以让服务运行前提前设置参数,而常见的2种设置参数方式为:

1. 命令行设置
2. 文件设置

命令行解析

使用tornado.options.define前定义,通常在模块的顶层。

然后,可以将这些选项作为以下属性的属性进行访问tornado.options.options

但要解析命令行参数时,需要使用tornado.options.parse_command_line来解析参数

具体代码如下:

python 复制代码
# main.py
import time
from tornado import web
import tornado
from tornado.options import define, options, parse_command_line

#define, 定义一些可以在命令行中传递的参数以及类型
define('port', default=8008, help="port to listen on", type=int)
define('debug', default=True, help="set tornado debug mode", type=bool)

#parse_command_line()
#options是一个类,全局只有一个options
class IndexHandler(web.RequestHandler):
    async def get(self):
        self.write("hello Tornado")

class IndexHandler2(web.RequestHandler):
    async def get(self):
        self.write("hello Tornado 你好")

if __name__ == "__main__":
    app = web.Application([
        ("/", IndexHandler),
        ("/index/", IndexHandler2)
    ], debug=options.debug)
    app.listen(options.port)
    tornado.ioloop.IOLoop.current().start()

文件设置

创建文件server.conf,将必要的参数直接写入即可

python 复制代码
port=8000
debug=True

设置好文件后,通过tornado.options.parse_config_file来解析

tip
有了以上方法,就可更新的设置服务器的各种通用参数了,如数据库参数、文件目录参数、服务器参数等

代码演练

python 复制代码
from tornado import web, ioloop
from tornado.options import define, options, parse_config_file

# 定义key来接收传递进来的参数
define('port', default=8000, help='port to listen on', type=int)
define('debug', default=True, help='set debug mode', type=bool)

# 解析文件传递进来的参数
parse_config_file('./server.conf')


class IndexHandler(web.RequestHandler):
    async def get(self):  # 协程
        self.write('Hello Tornado!!123123')


if __name__ == '__main__':
    app = web.Application([
        ('/', IndexHandler)
    ],
        # debug=True
        debug=options.debug
    )
    # app.listen(8000)
    app.listen(options.port)
    ioloop.IOLoop.current().start()
相关推荐
你的人类朋友21 分钟前
什么是API签名?
前端·后端·安全
会豪2 小时前
Electron-Vite (一)快速构建桌面应用
前端
中微子2 小时前
React 执行阶段与渲染机制详解(基于 React 18+ 官方文档)
前端
唐某人丶2 小时前
教你如何用 JS 实现 Agent 系统(2)—— 开发 ReAct 版本的“深度搜索”
前端·人工智能·aigc
中微子2 小时前
深入剖析 useState产生的 setState的完整执行流程
前端
架构师沉默3 小时前
设计多租户 SaaS 系统,如何做到数据隔离 & 资源配额?
java·后端·架构
遂心_3 小时前
JavaScript 函数参数传递机制:一道经典面试题解析
前端·javascript
小徐_23333 小时前
uni-app vue3 也能使用 Echarts?Wot Starter 是这样做的!
前端·uni-app·echarts
RoyLin3 小时前
TypeScript设计模式:适配器模式
前端·后端·node.js
遂心_3 小时前
深入理解 React Hook:useEffect 完全指南
前端·javascript·react.js