美文网首页
python tornado的应用

python tornado的应用

作者: 黑夜no烟丝 | 来源:发表于2019-04-01 22:06 被阅读0次

    tornado的安装

    pip install tornado
    

    如果出现报错:ImportError: cannot import name 'Type',可能是tornado版本和当前python版本不兼容的原因,我自己用的python3.5,导入后就报这样的错,解决办法

    pip unintsall tornado #卸载已经安装好的tornado
    pip install tornado==5.1.1 #重新安装tornado并制定版本
    

    然后就可以导入模块编写web服务器代码

    #main.py  程序入口,设置端口,初始化日志,启动监听
    import tornado.ioloop
    import tornado.web
    import tornado.options
    import conf.conf  as cfg
    from common.log import logger
    from tornado.options import define, options
    from HttpReqHandler import IndexHandler
    
    #定义变量,调用tornado.options.parse_command_line()方法完成设置
    define("port",default=cfg.INDEX_SERVER_PORT,help="server listening port",type=int) 
    
    application = tornado.web.Application([(cfg.INDEX_SERVER_REG,IndexHandler),])
    
    def start():
        tornado.options.parse_command_line()
        application.listen(options.port)
        tornado.ioloop.IOLoop.instance().start()
    
    if __name__ == "__main__":
        start()
        logger.debug("服务开启 /o\ ~/o\")
    ~
    

    这里除了基本的网络模块,我将这个小demo结构化了,分别自定义了日志模块,处理模块,配置模块,降低耦合,为以后扩展和直接使用更加方便

    #处理模块 这里写绑定了监听的回调方法,网络请求命中URI后的处理阶段
    import tornado.web
    class IndexHandler(tornado.web.RequestHandler):
        def post(self):
            self.write("post method")
        def get(self):
            self.write("get method")
    
    #日志模块
    import logging
    import tornado.web
    import conf.conf  as cfg
    from logging.handlers import TimedRotatingFileHandler
    
    class mylog():
        def __init__(self,appname,logfile):
            formatter = logging.Formatter(cfg.LOG_FMAT)
            self.RtHandler = TimedRotatingFileHandler(filename=logfile,when=cfg.LOG_WHEN,interval=cfg.LOG_INTERV,backupCount=cfg.LOG_BAKCOUNT)
            self.RtHandler.suffix = cfg.LOG_SUFFIX
            self.logger = logging.getLogger(appname)
            self.logger.setLevel(logging.DEBUG)
            self.logger.addHandler(self.RtHandler)
    
        def __fel__(self):
            self.logger.removeHandler(self.RtHandler)
    
    log = mylog('__name__',cfg.LOG_FILE)
    logger = log.logger
    
    #配置文件模块
    import logging
    
    #Index Server Setting
    
    INDEX_SERVER_PORT = 8070
    INDEX_SERVER_REG = r"/index"
    
    #Log Setting
    #默认日志启动等级
    LOG_LEVEL=logging.DEBUG
    #日志内容格式
    LOG_FMAT="%(asctime)s %(levelname)s  %(message)s"
    #日志文件存储路径及文件名前缀
    LOG_FILE="./logs/devinfo.log"
    LOG_FILE_MR=""
    LOG_FILE_FM=""
    LOG_SUFFIX="%y%m%d%H"
    #日志文件滚动间隔时间 "H" 小时 "D"天
    LOG_WHEN="H"
    LOG_INTERV=1
    #最大日志文件保留数量
    LOG_BAKCOUNT=9
    

    附:https://github.com/IvenSky/tornado-use-demo
    大家觉得满意的话,给我个star哦~~!

    相关文章

      网友评论

          本文标题:python tornado的应用

          本文链接:https://www.haomeiwen.com/subject/zlzbbqtx.html