python - 如何在 Python 日志记录配置文件中指定相对路径?

标签 python django logging

我有以下文件来配置日志记录:

[loggers]
keys=root

[handlers]
keys = root

[formatters]
keys = generic

# Loggers
[logger_root]
level = DEBUG
handlers = root

# Handlers
[handler_root]
class = handlers.RotatingFileHandler
args = ("test.log", "maxBytes=1*1024*1024", "backupCount=10")
level = NOTSET
formatter = generic

# Formatters
[formatter_generic]
format = %(asctime)s,%(msecs)03d %(levelname)-5.5s [%(name)s] %(message)s
datefmt = %Y-%m-%d %H:%M:%S

在开发中这很好用,但是当我部署应用程序时,test.log 试图写入我没有必要权限的路径。

所以我的问题是,如何在此配置文件中指定相对路径。

最佳答案

Mark 是对的,您在配置文件中的路径是相对于 logging.config.fileConfig 调用时的当前目录的。这取决于您的部署方法的详细信息。

您可能需要为您的文件指定一个绝对路径,方法是在“test.log”前面加上您知道运行代码的进程可写的目录。

另一个问题可能只是您的 Django 进程在其下运行的用户的权限问题:通常在运行开发服务器时它在您的帐户下运行,您通常不会遇到权限问题。在部署(例如使用 Apache 和 mod_wsgi)时,Apache 进程和/或 mod_wsgi 守护进程在不同的帐户下运行,可能需要授予相关文件夹的权限。

如果您需要更多帮助,请提供有关您的部署的更多详细信息,包括方法、日志文件目录的位置等。

关于python - 如何在 Python 日志记录配置文件中指定相对路径?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2806376/

相关文章:

python - 从N个点中可以找到多少个三角形,其中N个点的质心在其中?

javascript - Django Vue.js - 渲染多选下拉列表

python - 使用 Django 编写文件上传 API

git - 在 git 中显示每个作者更改的行数

python - virtualenv 蛋黄问题

python - 如何将数据文件作为矩阵导入并从 python 脚本运行 .m 文件?

python - 选择两个数据框列之一作为新列的输入

python - (托管 Django Pythonanywhere)Manage.pycollectstatic 返回 FileNotFoundError : [Errno 2]

slf4j simplelogger 的 Maven 和属性

jetty记录器错误: org. eclipse.jetty.util.log.Log.getLogger