Debian 上 Python 日志处理实践指南
一 基础配置与快速上手
import logging
logging.basicConfig(
level=logging.DEBUG,
format="%(asctime)s - %(name)s - %(levelname)s - %(message)s",
filename="app.log",
filemode="a"
)
logger = logging.getLogger(__name__)
logger.debug("调试信息")
logger.info("普通信息")
logger.warning("警告信息")
logger.error("错误信息")
二 日志轮转与保留策略
from logging.handlers import RotatingFileHandler, TimedRotatingFileHandler
# 按大小轮转
handler = RotatingFileHandler("app.log", maxBytes=10*1024*1024, backupCount=5)
handler.setFormatter(logging.Formatter("%(asctime)s - %(levelname)s - %(message)s"))
logging.getLogger().addHandler(handler)
# 按时间轮转
handler = TimedRotatingFileHandler("app_timed.log", when="midnight", interval=1, backupCount=7)
handler.setFormatter(logging.Formatter("%(asctime)s - %(levelname)s - %(message)s"))
logging.getLogger().addHandler(handler)
/var/log/myapp.log {
daily
rotate 8
compress
delaycompress
missingok
notifempty
create 0640 root adm
}
sudo logrotate --debug /etc/logrotate.d/myapp
sudo logrotate -f /etc/logrotate.conf
三 集成系统日志与 journalctl 查看
import logging
from logging.handlers import SysLogHandler
logger = logging.getLogger(__name__)
handler = SysLogHandler(address="/dev/log") # Debian 默认 syslog 套接字
handler.setFormatter(logging.Formatter("%(name)s: %(levelname)s %(message)s"))
logger.addHandler(handler)
logger.info("发送到系统日志")
四 配置文件与多环境管理
[loggers]
keys=root
[handlers]
keys=fileHandler
[formatters]
keys=simpleFormatter
[logger_root]
level=DEBUG
handlers=fileHandler
[handler_fileHandler]
class=FileHandler
level=DEBUG
formatter=simpleFormatter
args=('app_config.log', 'a')
[formatter_simpleFormatter]
format=%(asctime)s - %(name)s - %(levelname)s - %(message)s
datefmt=%Y-%m-%d %H:%M:%S
import logging.config
logging.config.fileConfig("logging.conf")
logger = logging.getLogger(__name__)
import logging.config
logging.config.dictConfig({
"version": 1,
"formatters": {
"standard": {"format": "%(asctime)s [%(levelname)s] %(name)s: %(message)s"}
},
"handlers": {
"default": {
"level": "INFO",
"class": "logging.StreamHandler",
"formatter": "standard"
}
},
"loggers": {
"": {"handlers": ["default"], "level": "INFO", "propagate": True}
}
})
五 权限与运维要点
touch app.log
sudo chown $USER:$USER app.log
sudo chmod 664 app.log
try:
1 / 0
except Exception:
logging.error("发生异常", exc_info=True)
from loguru import logger
logger.add("file.log", rotation="10 MB", level="DEBUG")
logger.add(sys.stdout, level="INFO")