django日誌,django-crontab,django郵件模塊

 django 日誌

四大塊,格式器,過濾器,處理器,日誌管理器python

LOGGING = {
    'version': 1,
    'disable_existing_loggers': True,
    'formatters': {# 日誌格式
       'standard': {
            'format': '%(asctime)s [%(threadName)s:%(thread)d] '
                      '[%(pathname)s:%(funcName)s:%(lineno)d] [%(levelname)s]- %(message)s'}
    },
    'filters': {# 過濾器
        'test':{
            '()': 'ops.TestFilter'
        }
    },
    'handlers': {# 處理器
        'null': {
            'level': 'DEBUG',
            'class': 'logging.NullHandler',
        },
        'error_handler': {# error內容輸出到另外的文件
            'level':'DEBUG',
            'class':'logging.handlers.RotatingFileHandler',
            'filename': os.path.join(LOG_DIR,'error.log'),#日誌輸出文件
            'maxBytes':1024*1024*5,#文件大小
            'backupCount': 5,#備份份數
            'formatter':'standard',#使用哪一種formatters日誌格式
            'encoding': 'utf8',
        },
        'file_handler': {# 記錄到日誌文件(須要建立對應的目錄,不然會出錯)
            'level':'DEBUG',
            'class':'logging.handlers.RotatingFileHandler',
            'filename': os.path.join(LOG_DIR,'service.log'),# 日誌輸出文件
            'maxBytes':1024*1024*5,#文件大小
            'backupCount': 5,#備份份數
            'formatter':'standard',#使用哪一種formatters日誌格式
                'encoding': 'utf8',
        },
        'console_handler':{# 輸出到控制檯
            'level': 'DEBUG',
            'class': 'logging.StreamHandler',
            'formatter': 'standard',
        },
    },
    'loggers': {# logging管理器
        'django': {
            # 'handlers': ['console_handler', 'file_handler', 'error_handler'],
            'handlers': ['console_handler', 'file_handler'],
            'filters': ['test'],
            'level': 'DEBUG'
        }
    }
}
import os
import django
import logging

os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'backend.settings')
django.setup()


def logger_demo():
    logger = logging.getLogger('django')
    logger.info('hello world')
    logger.info('hello world [FILTER FLAG]')

    logger.debug('debug message')

    logger.error('error message')


if __name__ == '__main__':
    logger_demo()

  

 

django-crontab 在win中不可用

crontablinux

https://lupython.gitee.io/2017/10/08/%E5%AE%9A%E6%97%B6%E4%BB%BB%E5%8A%A1/git

crontab 在django中提交給linux服務器使用
安裝
pip3 install django-crontabdjango


配置setting中增長app:django_crontab
#每一分鐘執行一次
CRONJOBS = [
('*/1 * * * *', 'cron.jobs.demo')
]服務器

'0 12 * * *', 'cron.jobs.demo' #天天12點整執行一次
'0 12 * * 1-5', 'cron.jobs.demo' #週一到週五天天12點整執行一次app

 在cron文件夾下jobs.py 添加demo函數,放執行代碼tcp

也能夠添加打印到log:函數

import logging測試

logger=logging.getLogger('django')加密

demo函數中最後放入logger.info(打印內容)


linux中查看crontab :
python3 manage.py crontab show
或者查看系統是否有定時任務:crontab -l
crontab -e 查看詳細
linux中添加crontab :
python3 manage.py crontab add
除了show,add以及還有remove/run命令

 

打印django日誌
cd log/
ls
tail -f service.log

 

django郵件模塊


簡單郵件傳輸協議simple mail transfer protocol
smtp服務使用tcp端口25,加密通道端口是465
使用QQ郵箱smtp服務須要受權碼

qq郵箱setting-開啓服務:IMAP/SMTP服務
受權碼:gwmwrhyhdtynbhag

django-settings中配置

# Email config
# QQ郵箱 SMTP 服務器地址
EMAIL_HOST = 'smtp.qq.com'
# 端口
EMAIL_PORT = 465
# 發送郵件的郵箱
EMAIL_HOST_USER = 'dujun31@vip.qq.com'
# 在郵箱中設置的客戶端受權密碼
EMAIL_HOST_PASSWORD = 'gwmwrhyhdtynbhag'
# 開啓TLS
EMAIL_USE_TLS = True
# 收件人看到的發件人
EMAIL_FROM = 'dujun31@vip.qq.com'

django測試列子

import os
import django
import smtplib
from backend import settings

from email.mime.text import MIMEText


os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'backend.settings')
django.setup()


def send_mail():
    msg = MIMEText("郵件通道測試", "plain", "utf-8")
    msg['FROM'] = "Mail Test"
    msg['Subject'] = "【Mail Test】"
    receivers = ['349553119@qq.com']
    server = smtplib.SMTP_SSL(settings.EMAIL_HOST, settings.EMAIL_PORT)
    server.set_debuglevel(1)
    server.login(settings.EMAIL_HOST_USER, settings.EMAIL_HOST_PASSWORD)
    server.sendmail(settings.EMAIL_FROM, receivers, msg.as_string())
    server.close()
    pass


if __name__ == '__main__':
    send_mail()

  

相關文章
相關標籤/搜索