I think, therefore I am.

Django日志

简单的Django日志

在settings里配置,会在屏幕输出日志

复制代码
复制代码
LOGGING = {
    'version': 1,
    'disable_existing_loggers': False,
    'handlers': {
        'console':{
            'level':'DEBUG',
            'class':'logging.StreamHandler',
        },
    },
    'loggers': {
        'django.db.backends': {
            'handlers': ['console'],
            'propagate': True,
            'level':'DEBUG',
        },
    }
}
复制代码
复制代码

实际项目中的日志

settings里配置

复制代码
复制代码
# 定义一下log文件存放的位置
BASE_LOG_DIR = os.path.join(BASE_DIR, "log")
# Django项目日志配置
LOGGING = {
    # 固定搭配的一个版本号
    'version': 1,
    # 禁用已经存在的logger实例
    'disable_existing_loggers': False,
    # 定义了三个日志打印或保存的格式
    'formatters': {
        # 标准的
        'standard': {
            'format': '[%(asctime)s][%(threadName)s:%(thread)d][task_id:%(name)s][%(filename)s:%(lineno)d]'
                      '[%(levelname)s][%(message)s]'
        },
        # 简单的格式
        'simple': {
            'format': '[%(levelname)s][%(asctime)s][%(filename)s:%(lineno)d]%(message)s'
        },
        # 收集
        'collect': {
            'format': '[%(asctime)s]%(message)s'
        }
    },
    # 日志的过滤条件
    'filters': {
        # 需要debug=True
        'require_debug_true': {
            '()': 'django.utils.log.RequireDebugTrue',
        },
    },

    # 定义几个处理日志的方法
    'handlers': {
        # 把日志都打印到终端窗口
        'console': {
            'level': 'DEBUG',
            'filters': ['require_debug_true'],  # 只有在Django debug为True时才在屏幕打印日志
            'class': 'logging.StreamHandler',
            'formatter': 'simple'
        },
        # 默认
        'default': {
            'level': 'INFO',
            'class': 'logging.handlers.RotatingFileHandler',  # 保存到文件,自动切
            'filename': os.path.join(BASE_LOG_DIR, "s8_info.log"),  # 日志文件
            'maxBytes': 1024 * 1024 * 50,  # 日志大小 50M
            'backupCount': 5,  # 日志文件个数
            'formatter': 'standard',
            'encoding': 'utf-8',
        },
        # 专门记录错误日志的
        'error': {
            'level': 'ERROR',
            'class': 'logging.handlers.RotatingFileHandler',  # 保存到文件,自动切
            'filename': os.path.join(BASE_LOG_DIR, "s8_err.log"),  # 日志文件
            'maxBytes': 1024 * 1024 * 50,  # 日志大小 50M
            'backupCount': 5,
            'formatter': 'standard',
            'encoding': 'utf-8',
        },
        'collect': {
            'level': 'INFO',
            'class': 'logging.handlers.RotatingFileHandler',  # 保存到文件,自动切
            'filename': os.path.join(BASE_LOG_DIR, "s8_collect.log"),
            'maxBytes': 1024 * 1024 * 50,  # 日志大小 50M
            'backupCount': 5,
            'formatter': 'collect',
            'encoding': "utf-8"
        }
    },
    # 最后处理logger实例的配置
    'loggers': {
       # 默认的logger应用如下配置
        '': {
            'handlers': ['default', 'console', 'error'],  # 上线之后可以把'console'移除
            'level': 'DEBUG',

        },
        # 名为 'collect'的logger还单独处理
        'collect': {
            'handlers': ['console', 'collect'],
            'level': 'INFO',
        },
        'collect.son': {
            'handlers': ['console',],
            'level': 'INFO',
            'propagate': False,
        }
    },
}
复制代码
复制代码

views视图函数中使用

复制代码
复制代码
from django.shortcuts import render
from django.core.paginator import Paginator, EmptyPage, PageNotAnInteger
import logging
# 生成一个以当前文件名为日志实例名字的logger
logger = logging.getLogger(__name__)

# 自己随意起名生成logger
collect_logger = logging.getLogger("collect")

data = []
for i in range(1, 302):
    tmp = {"id": i, "name": "alex-{}".format(i)}
    data.append(tmp)


def user_list(request):
    # 去到当前请求的页码
    current_page = request.GET.get('page')
    logger.debug(current_page)
    paginator = Paginator(data, 10)
    # per_page: 每页显示条目数量
    # count:    数据总个数
    # num_pages:总页数
    # page_range:总页数的索引范围,如: (1,10),(1,200)
    # page:     page对象
    try:
        users = paginator.page(current_page)
        # has_next              是否有下一页
        # next_page_number      下一页页码
        # has_previous          是否有上一页
        # previous_page_number  上一页页码
        # object_list           分页之后的数据列表
        # number                当前页
        # paginator             paginator对象
    except PageNotAnInteger as e:
        logger.warning("传来的页码它不是个数字")
        logger.warning(str(e))
        # 如果请求的页码不是数字,默认返回第一页
        users = paginator.page(1)
    except EmptyPage as e:
        logger.warning("传来的页码它不正常")
        logger.warning(str(e))
        # 如果请求的页码超过了总页码,默认返回最后一页
        logger.debug("顺利走到了这一步,可以给前端页面返回数据了。。。")
        users = paginator.page(paginator.num_pages)

    # 专门用来收集一些需要特殊保存的信息
    collect_logger.info("哈哈哈哈")

    return render(request, 'user_list.html', {'user_list': users})
posted @ 2018-02-03 11:50  躬行致远  阅读(238)  评论(0编辑  收藏  举报