您的位置:首页 >Debian Python如何进行错误日志记录
发布于2026-05-02 阅读(0)
扫一扫,手机访问
在Debian环境下用Python处理错误日志,其实比你想象的要简单。核心工具就是Python自带的logging模块,它功能强大,配置起来也相当直观。下面这个示例,就能帮你快速上手,看看如何配置并让它开始工作。

安装Python(如果尚未安装):
首先,确保你的Debian系统已经装好了Python。打开终端,执行下面这两条命令就行:
sudo apt update
sudo apt install python3 python3-pip
创建一个Python脚本(例如log_example.py):
接下来,我们创建一个脚本文件。把下面的代码复制进去,它演示了如何配置日志记录,并捕获一个典型的错误。
import logging
# 配置日志记录
logging.basicConfig(level=logging.ERROR, # 设置日志级别为ERROR
format='%(asctime)s - %(levelname)s - %(message)s', # 设置日志格式
filename='error.log' # 设置日志文件名
)
try:
# 一些可能引发异常的代码
1 / 0
except ZeroDivisionError as e:
# 记录错误日志
logging.error("发生了一个除零错误: %s", e)
运行脚本:
保存文件后,在终端里运行它:
python3 log_example.py
查看日志文件:
脚本运行后,错误信息已经被记录下来了。用cat命令查看生成的日志文件:
cat error.log
这时,你应该能看到类似下面这样的输出,时间戳、错误级别和具体信息一目了然:
2023-04-14 12:34:56,789 - ERROR - 发生了一个除零错误: division by zero
上面的代码虽然简短,但几个关键配置点值得展开说说:
logging.basicConfig: 这是快速配置日志的核心方法。
level=logging.ERROR:这个设置决定了日志记录的“门槛”。设为ERROR意味着只有ERROR级别及以上的严重消息才会被捕获并写入文件,那些DEBUG、INFO之类的信息就被过滤掉了。format='%(asctime)s - %(levelname)s - %(message)s':定义了日志消息的“样子”。这里包含了时间戳、日志级别和具体的消息内容,格式清晰,便于后续排查。filename='error.log':指定了日志输出的目的地,这里就是当前目录下的error.log文件。logging.error: 当在except块中捕获到异常后,就是用它来记录错误。你可以像示例中那样,将异常对象e格式化成消息的一部分,让日志内容更具体。
基础配置能满足大多数简单场景,但如果你想更精细地控制日志,还有更多选项可以探索。
日志级别: Python的logging模块定义了多个级别,从最详细到最严重依次是:
DEBUG:最详细的调试信息。INFO:确认程序按预期运行的一般信息。WARNING:表明一些意外情况,但程序还能继续运行。ERROR:由于更严重的问题,程序已无法执行某些功能。CRITICAL:严重的错误,表明程序本身可能无法继续运行。根据实际需要调整level参数,可以平衡日志的详细度和文件大小。
日志文件轮转: 对于需要长期运行的服务,日志文件可能会变得非常大。这时,文件轮转(Log Rotation)功能就派上用场了。你可以使用logging.handlers里的RotatingFileHandler或TimedRotatingFileHandler。前者按文件大小轮转,后者按时间间隔轮转。下面是一个按大小轮转的例子:
import logging
from logging.handlers import RotatingFileHandler
# 配置日志记录
logger = logging.getLogger('my_logger')
logger.setLevel(logging.ERROR)
# 创建一个RotatingFileHandler,最大文件大小为1MB,最多保留3个备份文件
handler = RotatingFileHandler('error.log', maxBytes=1*1024*1024, backupCount=3)
formatter = logging.Formatter('%(asctime)s - %(levelname)s - %(message)s')
handler.setFormatter(formatter)
logger.addHandler(handler)
try:
1 / 0
except ZeroDivisionError as e:
logger.error("发生了一个除零错误: %s", e)
这样配置后,当error.log文件达到1MB时,它会被重命名(如error.log.1),然后创建一个新的error.log,最多保留3个备份文件,有效防止磁盘被日志塞满。
总的来说,通过合理配置logging模块,你就能在Debian系统上构建一个既可靠又灵活的错误日志记录机制,为程序的稳定运行和问题排查打下坚实基础。
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
正版软件
正版软件
正版软件
正版软件
正版软件
1
2
3
7
9