配置django全局日志模块

1、在setting.py里增加需要的日志配置

LOGGING = {
    'version': 1,
    'disable_existing_loggers': False,
    'formatters': {
        'standard': {
            'format': '%(asctime)s - %(name)s - %(levelname)s - %(message)s',
            'datefmt': '%Y-%m-%d %H:%M:%S'
        },
    'simple': {
            'format': '[%(levelname)s]> %(message)s',
            'datefmt': '%Y-%m-%d %H:%M:%S'
        },
    },
    'handlers': {
        'console': {
            'level': 'DEBUG',
            'class': 'logging.StreamHandler',
            'formatter': 'standard'
        },
        'file': {
            'level': 'DEBUG',
            'class': 'logging.FileHandler',
            'filename': 'logs/{}.logs'.format(time.strftime("%Y-%m-%d",time.localtime())),
            'formatter': 'standard',
            'encoding': 'utf-8'
        },
        'rfile': {
            'level': 'DEBUG',
            'class': 'logging.handlers.TimedRotatingFileHandler',
            'filename': 'log.log',
            'formatter': 'standard',
            'encoding': 'utf-8'
        },
    },
    'loggers': {
        'django': {
            'handlers': ['console','file','rfile'],
            'level': 'DEBUG',
            'propagate': False,
        },
    },
}

2、在视图里增加引用代码

logger=logging.getLogger('django')
def index(request:HttpRequest):
    logger.info("{} - {} - {} ".format(web.lib.get_real_ip(request),request.path,"hello"))
    return HttpResponse("hello")

3、增加lib.py

def get_real_ip(request):
    ip = "127.0.0.1"
    if "HTTP_X_FORWARDED_FOR" in request.META.keys():
        ip = request.META['HTTP_X_FORWARDED_FOR']
    elif "X_FORWARDED_FOR" in request.META.keys():
        ip = request.META['X_FORWARDED_FOR']
    elif "REMOTE_ADDR" in request.META.keys():
        ip = request.META["REMOTE_ADDR"]
    else:
        ip = "127.0.0.1"
    return ip

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值