centos

CentOS中Python日志配置与管理

小樊
44
2025-07-14 23:35:04
栏目: 编程语言

在CentOS系统中配置和管理Python日志通常涉及以下步骤:

1. 安装Python和pip

确保你的CentOS系统上已经安装了Python和pip(Python的包管理器)。如果没有安装,可以使用以下命令进行安装:

sudo yum install python3 python3-pip

2. 创建Python脚本

创建一个Python脚本文件,例如 app.py,并在其中配置日志记录。以下是一个基本的日志配置示例:

import logging

# 配置日志记录
logging.basicConfig(
    level=logging.INFO,
    format='%(asctime)s - %(name)s - %(levelname)s - %(message)s',
    filename='app.log',  # 日志文件名
    filemode='a'  # 追加模式
)

# 获取日志记录器
logger = logging.getLogger(__name__)

# 记录不同级别的日志
logger.debug('This is a debug message')
logger.info('This is an info message')
logger.warning('This is a warning message')
logger.error('This is an error message')
logger.critical('This is a critical message')

3. 运行Python脚本

在终端中运行你的Python脚本:

python3 app.py

4. 查看日志文件

运行脚本后,你会在当前目录下看到一个名为 app.log 的日志文件。你可以使用以下命令查看日志文件内容:

cat app.log

5. 配置日志轮转

为了防止日志文件过大,可以使用 logging.handlers.RotatingFileHandler 来配置日志轮转。修改 app.py 中的日志配置部分:

from logging.handlers import RotatingFileHandler

# 配置日志记录
logging.basicConfig(
    level=logging.INFO,
    format='%(asctime)s - %(name)s - %(levelname)s - %(message)s',
    filename='app.log',
    filemode='a',
    handlers=[
        RotatingFileHandler('app.log', maxBytes=10*1024*1024, backupCount=5),
        logging.StreamHandler()
    ]
)

6. 配置系统级日志

如果你希望将Python日志发送到系统级日志(例如syslog),可以使用 logging.handlers.SysLogHandler。修改 app.py 中的日志配置部分:

from logging.handlers import SysLogHandler

# 配置日志记录
logging.basicConfig(
    level=logging.INFO,
    format='%(asctime)s - %(name)s - %(levelname)s - %(message)s',
    handlers=[
        SysLogHandler(address='/dev/log'),
        logging.StreamHandler()
    ]
)

7. 使用配置文件管理日志

为了更方便地管理日志配置,可以使用配置文件。Python的 logging 模块支持使用配置文件进行配置。常见的配置文件格式有INI和JSON。

使用INI配置文件

创建一个名为 logging.conf 的文件,内容如下:

[loggers]
keys=root,my_logger

[handlers]
keys=fileHandler,consoleHandler

[formatters]
keys=simpleFormatter

[logger_root]
level=DEBUG
handlers=fileHandler,consoleHandler

[logger_my_logger]
level=DEBUG
handlers=fileHandler,consoleHandler
qualname=my_logger
propagate=0

[handler_fileHandler]
class=FileHandler
level=DEBUG
formatter=simpleFormatter
args=('my_app.log', 'a')

[handler_consoleHandler]
class=StreamHandler
level=INFO
formatter=simpleFormatter
args=(sys.stdout,)

[formatter_simpleFormatter]
format=%(asctime)s - %(name)s - %(levelname)s - %(message)s
datefmt=%Y-%m-%d %H:%M:%S

然后在Python脚本中加载配置文件:

import logging
import logging.config

# 加载配置文件
logging.config.fileConfig('logging.conf')

# 获取日志记录器
logger = logging.getLogger('my_logger')

# 记录日志
logger.debug('This is a debug message')
logger.info('This is an info message')
logger.warning('This is a warning message')
logger.error('This is an error message')
logger.critical('This is a critical message')

使用JSON配置文件

创建一个名为 logging.json 的文件,内容如下:

{
    "version": 1,
    "formatters": {
        "simple": {
            "format": "%(asctime)s - %(name)s - %(levelname)s - %(message)s"
        }
    },
    "handlers": {
        "file": {
            "class": "logging.FileHandler",
            "level": "DEBUG",
            "formatter": "simple",
            "filename": "my_app.log",
            "mode": "a"
        },
        "console": {
            "class": "logging.StreamHandler",
            "level": "INFO",
            "formatter": "simple",
            "stream": "ext://sys.stdout"
        }
    },
    "loggers": {
        "my_logger": {
            "handlers": ["file", "console"],
            "level": "DEBUG",
            "propagate": false
        }
    }
}

然后在Python脚本中加载配置文件:

import logging
import json
import logging.config

# 加载配置文件
with open('logging.json', 'rt') as f:
    config = json.load(f)
logging.config.dictConfig(config)

# 获取日志记录器
logger = logging.getLogger('my_logger')

# 记录日志
logger.debug('This is a debug message')
logger.info('This is an info message')
logger.warning('This is a warning message')
logger.error('This is an error message')
logger.critical('This is a critical message')

通过以上步骤,你可以在CentOS系统上配置和管理Python日志。根据你的需求,可以选择不同的日志处理程序和格式化程序来满足你的日志管理需求。

0
看了该问题的人还看了