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哦~~!
网友评论