记录下Django关于日期的配置,以及如何根据日期滚动切割日志的问题。
配置的源码在githun上 https://github.com/blackmatrix7/django-examples/tree/master/django_logs
准备
环境
python 3.5.2
djang 2.0.5
创建项目
使用命令快速新建django项目,示例的项目名为proj。
开始
修改配置文件
日志部分配置,参考Django官方手册
https://docs.djangoproject.com/en/2.0/topics/logging/#examples
LOGGING属性实际上是一个dictConfig
关于dictConfig的配置,参考Python官方手册
https://docs.python.org/3/library/logging.config.html#logging-config-dictschema
LOGGING = { 'version': 1, 'disable_existing_loggers': False, 'formatters': { 'verbose': { 'format': '[%(asctime)s] [%(levelname)s] %(message)s' }, }, 'handlers': { # 输出日志的控制台 'console': { 'level': 'INFO', 'class': 'logging.StreamHandler', 'formatter': 'verbose' }, # 输出日志到文件,按日期滚动 'file': { 'level': 'DEBUG', 'class': 'logging.handlers.TimedRotatingFileHandler', # TimedRotatingFileHandler的参数 # 参照https://docs.python.org/3/library/logging.handlers.html#timedrotatingfilehandler # 目前设定每天一个日志文件 'filename': 'logs/manage.log', 'when': 'midnight', 'interval': 1, 'backupCount': 100, 'formatter': 'verbose' }, # 发送邮件,目前腾讯云、阿里云的服务器对外发送邮件都有限制,暂时不使用 'email': { 'level': 'ERROR', 'class': 'django.utils.log.AdminEmailHandler', 'include_html': True, } }, 'loggers': { # 不同的logger 'django': { 'handlers': ['console', 'file'], 'level': 'INFO', 'propagate': True, }, }, }
创建logs目录
cd django_logs/ mkdir logs
新增django_logs/logger.py
import logging logger = logging.getLogger('django')
验证
创建app
python manage.py startapp app
编写视图函数
编写一个视图函数,使用logger用于往日志文件写入日志
django_logs/app/views.py
from logger import logger from django.shortcuts import HttpResponse def test_logger(request): logger.info('test log') return HttpResponse('test log')
配置Url
django_logs/proj/urls.py
from app import views from django.contrib import admin from django.urls import path urlpatterns = [ path('admin/', admin.site.urls), path('test_log/', views.test_logger), ]
调用
访问 http://127.0.0.1:8000/test_log/ ,在logs/manage.log中成功写入
[2018-05-18 08:35:44,317] [INFO] test log [2018-05-18 08:35:44,318] [INFO] "GET /test_log/ HTTP/1.1" 200 8
最后,修改系统日期,可以看到日志文件会按天进行分割。
日志写入仅仅对于创建的logger对象有效,如果需要使用logging直接写入,则需要再做一些修改:让logging模块使用django的dictConfig。
import logging.config from django.conf import settings logger = logging.getLogger('django') logging.config.dictConfig(settings.LOGGING)
以上这篇Django 日志配置按日期滚动的方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
更新日志
- 《丁当 20首重量级歌曲 Fu Good 下一站天后 2CD》[WAV/分轨][650MB]
- 歌莉雅.2012-My.Voice.Story【环星】【FLAC分轨】
- 群星.1993-一曲成名·青春无悔【飞碟】【WAV+CUE】
- 刘德华.2000-爱无知(金装版)【NEWMELODY】【WAV+CUE】
- 许巍《时光漫步》1CD[FLAC/分轨][804.3MB]
- 群星《2024第一季度百度歌曲排行抖音榜top100》1CD[FLAC/分轨][2.3GB]
- 张柏芝《全新经验》[FLAC/分轨][450MB]
- 唐朝.2008-浪漫骑士【音乐家】【WAV+CUE】
- 张芸京.2016-失败的高歌【泡耳音乐】【WAV+CUE】
- 群星.1991-音乐工厂1·皇后大道东【音乐工厂】【WAV+CUE】
- 群星.1992-音乐工厂2·首都【音乐工厂】【WAV+CUE】
- 群星.1994-音乐工厂3·儿童乐园【音乐工厂】【WAV+CUE】
- 胡鸿钧.2021-ex:CHANGE【星梦娱乐】【WAV+CUE】
- 班得瑞原装进口《第一张新世纪专辑:仙境》1CD[APE/CUE分轨][292.3MB]
- 伍佰《摇滚教父 伍佰黄金精选 2CD》[WAV+CUE][990MB]