python tornado的应用

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哦~~!

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 模块和包 一 模块 1 什么是模块? 常见的场景:一个模块就是一个包含了python定义和声明的文件,文件名就是...
    go以恒阅读 2,295评论 0 4
  • 模块与包 一、概念 提起python文件,经常会听到3个名词,python脚本,python模块,python包。...
    唯老阅读 380评论 0 7
  • 发现 关注 消息 iOS 第三方库、插件、知名博客总结 作者大灰狼的小绵羊哥哥关注 2017.06.26 09:4...
    肇东周阅读 12,246评论 4 61
  • 从宜家自助购物想到,经济型酒店能否也开展自助型服务,如:学习线上值机,能否线上自助选房;到店后刷身份证后,也可自助...
    投资时代阅读 318评论 0 0
  • 特别简的介 去年开始火遍南北的 PWA 技术落地情况有负重望,主要源于 safrai 对于这一技术支持不甚理想,不...
    溪离欣洛阅读 8,647评论 0 4