tornado deploy django和日志重复输出

tornado deploy django和日志重复输出,django,logging,tornado,Django,Logging,Tornado,在我的项目中,我使用tornado服务器部署了django项目,我的tornado主要功能是: def main(): tornado.options.options.logging = None tornado.options.parse_command_line() os.environ['DJANGO_SETTINGS_MODULE'] = 'Zero.settings' application = get_wsgi_application() co

在我的项目中,我使用tornado服务器部署了django项目,我的tornado主要功能是:

def main():
    tornado.options.options.logging = None
    tornado.options.parse_command_line()
    os.environ['DJANGO_SETTINGS_MODULE'] = 'Zero.settings'
    application = get_wsgi_application()
    container = tornado.wsgi.WSGIContainer(application)
    http_server = tornado.httpserver.HTTPServer(container, xheaders=True)
    http_server.listen(tornado.options.options.port)
    tornado.ioloop.IOLoop.current().start()
当我使用
tornado.options.options.logging=None
禁用tornado日志输出,但它仍然在我的控制台中两次输出日志消息时,我的django日志配置为:

LOGGING = {
    'version': 1,
    'disable_existing_loggers': True,
    'formatters': {
       'standard': {
            'format': '%(asctime)s [%(threadName)s] [%(name)s:%(funcName)s] [%(levelname)s]- %(message)s'}
    },
    'filters': {
    },
    'handlers': {
        'error': {
            'level': 'ERROR',
            'class': 'logging.handlers.RotatingFileHandler',
            'filename': os.path.join(BASE_DIR, 'log', 'error.log'),
            'maxBytes': 1024*1024*5,
            'backupCount': 5,
            'formatter': 'standard',
        },
        'console':{
            'level': 'INFO',
            'class': 'logging.StreamHandler',
            'formatter': 'standard'
        },
    },
    'loggers': {
        'django': {
            'handlers': ['console'],
            'level': 'INFO',
            'propagate': True
        },
    }
}
最终结果是:

2018-06-15 17:40:55,724 [MainThread] [base_views:get] [INFO]- get message correct
INFO:base_views:get message correct
那么我能做些什么来解决这个问题呢。
感谢您。

您只配置了
django
记录器,而不是根记录器。当Tornado发现根记录器未配置时,它会添加自己的最后处理程序(使用
logging.basicConfig
而不是
Tornado.log
)。由于python记录器的传播方式,这会导致复制任何其他记录器

使用
tornado.options.options.logging=None
时,应确保自己配置根记录器,或使用
propagate=False
配置所有其他处理程序。在这种情况下,将配置的
loggers.django
部分移动到一个新的
root
部分:

'handlers': {...}
'root': {
  'handlers': ['console'],
  'level': 'INFO',
},

你为什么在龙卷风上运行Django?这种架构效率非常低。@xyres,因为我需要大量HTTP持久连接,而Tornado可以轻松做到这一点。当许多请求被处理时,uwsgi服务器将重新启动,所以我选择Tornado。