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

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,029评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,238评论 3 388
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,576评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,214评论 1 287
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,324评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,392评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,416评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,196评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,631评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,919评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,090评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,767评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,410评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,090评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,328评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,952评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,979评论 2 351

推荐阅读更多精彩内容

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