日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

gunicorn 配置日志

發布時間:2024/10/8 编程问答 27 豆豆
生活随笔 收集整理的這篇文章主要介紹了 gunicorn 配置日志 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
日志

以flask舉例

# mytest.py from flask import Flaskapp = Flask(__name__)@app.route("/") def hello():return "hello world"def run():app.run("0.0.0.0", 12345)if __name__ == "__main__":run()

三種配置方式

# logging.conf [loggers] keys = root,gunicorn.error,gunicorn.access[handlers] keys=console,logfile[formatters] keys=json[logger_root] level=INFO handlers=console,logfile[logger_gunicorn.error] level = INFO handlers = logfile propagate = 1 qualname = gunicorn.error[logger_gunicorn.access] level = INFO handlers = logfile propagate = 0 qualname = gunicorn.access[handler_console] class=logging.StreamHandler formatter=json args=(sys.stdout, )[handler_logfile] class=logging.handlers.TimedRotatingFileHandler formatter=json args=('logs.log', 'midnight', )[formatter_json] format=%(message)s class=pythonjsonlogger.jsonlogger.JsonFormatter # gunicorn.conf import logging from logging.handlers import TimedRotatingFileHandler import os, sys import multiprocessingfrom gunicorn.glogging import Loggerfilepath = "/data/zgx/test/test/flaskTest/list_embedding/log/" th_acc = TimedRotatingFileHandler(when="S", backupCount=7, filename=filepath + "access.log") th_err = TimedRotatingFileHandler(when="S", backupCount=7, filename=filepath + "error.log") th_acc.setFormatter(logging.Formatter("[%(asctime)s] %(levelname)s | %(message)s")) th_err.setFormatter(logging.Formatter("[%(asctime)s] %(levelname)s | %(message)s"))# gunicorn源碼中不支持按日切分日志 class SplitLogger(Logger):def __init__(self, cfg):super(SplitLogger, self).__init__(cfg)self.access_log.addHandler(th_acc)self.error_log.addHandler(th_err)# Server Socket bind = ["0.0.0.0:1316"] backlog = 512 chdir = "/data/prod/project/list_embedding/service_py" timeout = 100 # Worker Processes worker_class = "gevent" workers = multiprocessing.cpu_count() * 2 + 1 # Logging loglevel = "info"access_log_format = '%(t)s %(p)s %(h)s "%(r)s" %(s)s %(L)s %(b)s %(f)s" "%(a)s"' accesslog = "/data/prod/project/list_embedding/service_py/gunicorn_access.log"error_log_format = '%(t)s %(p)s %(h)s "%(r)s" %(s)s %(L)s %(b)s %(f)s" "%(a)s"' errorlog = "/data/prod/project/list_embedding/service_py/gunicorn_error.log"logger_class = SplitLogger # 第一種 gunicorn mytest:app --log-conf=logging.conf # 第二種 gunicorn mytest:app -c gunicorn.conf # 第三種 gunicorn mytest:app --access-logfile '/xxx/access.log'# 具體配置可以詳見官網 # https://docs.gunicorn.org/en/latest/settings.html#logger-class

總結

以上是生活随笔為你收集整理的gunicorn 配置日志的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 成人美女毛片 | 狠狠干天天操 | 亚洲av成人无码网天堂 | 国产一级一区二区 | 一级肉体全黄裸片 | 精品人妻一区二区三区免费 | 亚洲日本不卡 | 蜜臀av一区二区 | 一级全黄色片 | 激情网av| 一区二区三区日本视频 | 女儿的朋友在线播放 | 古代黄色一级片 | 五月天中文字幕 | 国产精品久久久久久久久久 | 久久国产精品综合 | 黑人无套内谢中国美女 | 一本一道波多野结衣av黑人 | 影音先锋一区 | 粉嫩av懂色av蜜臀av分享 | 精品少妇人妻av一区二区 | 欧美毛片在线观看 | 91麻豆精品国产午夜天堂 | 国产精品36p | 中文字幕 亚洲一区 | 一区二区日韩欧美 | 日韩一区二区不卡 | 一区二区免费在线观看视频 | 午夜视频福利网站 | 国产在线一区二区视频 | 中文字幕无码人妻少妇免费 | 日韩精品一二三区 | 国产强伦人妻毛片 | 自拍愉拍 | 极品美女一区二区三区 | 清纯唯美亚洲激情 | 91大神视频在线播放 | 中文字幕av在线 | 国产福利第一页 | 免费视频一区二区 | 亚洲狠狠婷婷综合久久久久图片 | 狠狠夜夜 | 成人播放器 | 亚洲成人高清在线 | 久久精品一区二区在线观看 | jizz日本在线观看 | 久久色在线 | 欧美天天 | 狠狠干导航 | 一级草逼片 | 亚洲综合站 | 九九色影院 | 欧美精品久久久久 | 激情网站在线 | 色男人在线| av视觉盛宴| 免费中文字幕日韩 | 超碰95在线 | 中文字幕一区二区久久人妻 | 亚洲男人天堂2024 | 中文字幕偷拍 | 男生草女生的视频 | 免费性网站 | 国产精品国产成人国产三级 | 草草地址线路①屁屁影院成人 | 精品人妻无码一区二区三区 | 色五丁香 | 在线免费精品视频 | 欧美激情一区二区三区免费观看 | 一区二区不卡免费视频 | 欧美激情aaa | jizz高潮| 日本久久成人 | 老女人人体欣赏a√s | 国产男人天堂 | 免费一级黄色片 | 91精品国产自产在线观看 | 亚洲精品视频免费 | 烈性摔跤 | 中文字幕在线观 | 米奇影视第四色 | 操到喷水| 欧美精品一区二区性色a+v | 免费av网址在线观看 | 日日夜夜网 | 猛男大粗猛爽h男人味 | 亚洲精品乱码久久久久久久 | 成人手机看片 | 欧美特黄一级 | 看黄网站在线观看 | 免费看黄20分钟 | 老司机午夜在线 | 国产精选一区 | 亚洲av无码一区二区乱子伦as | 操操日 | 秘密基地电影免费版观看国语 | 理论片中文字幕 | 中文字幕无码不卡免费视频 | 国内自拍视频在线播放 |