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

你可能感兴趣的:(python tornado的应用)