uwsgi + flask logging.config 不工作并且还破坏了应用程序
uwsgi + flask logging.config not working and also breaks application
过去 5 个小时一直在寻找答案,但一无所获。
我有一个 flask (python 2.7) 应用程序可以与 uwsgi 一起正常工作,但我没有日志。
/etc/uwsgi/uwsgi.ini 配置:
[uwsgi]
socket = /tmp/uwsgi.sock
chown-socket = nginx:nginx
chmod-socket = 664
cheaper = 2
processes = 16
/app/uwsgi.ini
[uwsgi]
module = main
callable = app
/app/main.py(没有 uwsgi 也能正常工作)
app = Flask(__name__)
...
...
...
if __name__ == "__main__":
with open("{0}/logging.config.json".format(CONFIG_PATH), "r") as fd:
logging.config.dictConfig(json.load(fd))
app.run()
logging.config.json:
...
"formatters": {
"simple": {
"()": "pythonjsonlogger.jsonlogger.JsonFormatter",
"format": "%(asctime)s %(levelname)s %(module)s %(message)s"
}
...
"handlers": {
"console":{
"level": "DEBUG",
"class": "logging.StreamHandler",
"formatter": "simple",
"stream" : "ext://sys.stdout"
},
"loggers": { },
"root": {
"handlers": ["console"],
"level": "DEBUG"
}
}
我还尝试将记录器移到 main 之外(有人 post 建议这样做),如下所示:
app = Flask(__name__)
with open("{0}/logging.config.json".format(CONFIG_PATH), "r") as fd:
logging.config.dictConfig(json.load(fd))
...
...
...
if __name__ == "__main__":
app.run()
它只是破坏了 uwsgi:
--- no python application found, check your startup logs for errors ---
与应用程序声明之前的日志记录声明相同(但没有错误 - 应用程序无法运行)
有什么建议吗?
嗯,我发现了问题:
"formatters": {
"simple": {
"()": "pythonjsonlogger.jsonlogger.JsonFormatter",
"format": "%(asctime)s %(levelname)s %(module)s %(message)s"
}
pythonjsonlogger 是我几十年前手动安装并忘记的库。声明 logging.config.dictConfig() 时未正确加载。
此外,对于任何看到这个的人,uWSGI 只调用 app.run() 并且如果你想看到任何日志你应该在你声明应用程序之前声明日志记录。例如:
with open("{0}/logging.config.json".format(CONFIG_PATH), "r") as fd:
logging.config.dictConfig(json.load(fd))
app = Flask(__name__)
...
...
...
if __name__ == "__main__":
app.run()
过去 5 个小时一直在寻找答案,但一无所获。
我有一个 flask (python 2.7) 应用程序可以与 uwsgi 一起正常工作,但我没有日志。
/etc/uwsgi/uwsgi.ini 配置:
[uwsgi]
socket = /tmp/uwsgi.sock
chown-socket = nginx:nginx
chmod-socket = 664
cheaper = 2
processes = 16
/app/uwsgi.ini
[uwsgi]
module = main
callable = app
/app/main.py(没有 uwsgi 也能正常工作)
app = Flask(__name__)
...
...
...
if __name__ == "__main__":
with open("{0}/logging.config.json".format(CONFIG_PATH), "r") as fd:
logging.config.dictConfig(json.load(fd))
app.run()
logging.config.json:
...
"formatters": {
"simple": {
"()": "pythonjsonlogger.jsonlogger.JsonFormatter",
"format": "%(asctime)s %(levelname)s %(module)s %(message)s"
}
...
"handlers": {
"console":{
"level": "DEBUG",
"class": "logging.StreamHandler",
"formatter": "simple",
"stream" : "ext://sys.stdout"
},
"loggers": { },
"root": {
"handlers": ["console"],
"level": "DEBUG"
}
}
我还尝试将记录器移到 main 之外(有人 post 建议这样做),如下所示:
app = Flask(__name__)
with open("{0}/logging.config.json".format(CONFIG_PATH), "r") as fd:
logging.config.dictConfig(json.load(fd))
...
...
...
if __name__ == "__main__":
app.run()
它只是破坏了 uwsgi:
--- no python application found, check your startup logs for errors ---
与应用程序声明之前的日志记录声明相同(但没有错误 - 应用程序无法运行)
有什么建议吗?
嗯,我发现了问题:
"formatters": {
"simple": {
"()": "pythonjsonlogger.jsonlogger.JsonFormatter",
"format": "%(asctime)s %(levelname)s %(module)s %(message)s"
}
pythonjsonlogger 是我几十年前手动安装并忘记的库。声明 logging.config.dictConfig() 时未正确加载。
此外,对于任何看到这个的人,uWSGI 只调用 app.run() 并且如果你想看到任何日志你应该在你声明应用程序之前声明日志记录。例如:
with open("{0}/logging.config.json".format(CONFIG_PATH), "r") as fd:
logging.config.dictConfig(json.load(fd))
app = Flask(__name__)
...
...
...
if __name__ == "__main__":
app.run()